public void QueueFunc <T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, R>(MyFunc <T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, R> action, T1 t1, T2 t2, T3 t3, T4 t4, T5 t5, T6 t6, T7 t7, T8 t8, T9 t9, T10 t10, T11 t11) { bool needUseLambda = true; ObjectPool <PoolAllocatedFunc <T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, R> > pool; m_ActionPools.GetOrNewData(out pool); if (null != pool) { PoolAllocatedFunc <T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, R> helper = pool.Alloc(); if (null != helper) { helper.SetPoolRecycleLock(m_LockForAsyncActionRun); helper.Init(action, t1, t2, t3, t4, t5, t6, t7, t8, t9, t10, t11); m_Actions.Enqueue(helper.Run); needUseLambda = false; } } if (needUseLambda) { m_Actions.Enqueue(() => { action(t1, t2, t3, t4, t5, t6, t7, t8, t9, t10, t11); }); LogSystem.Warn("QueueAction {0}({1},{2},{3},{4},{5},{6},{7},{8},{9},{10},{11}) use lambda expression, maybe out of memory.", action.Method.ToString(), t1, t2, t3, t4, t5, t6, t7, t8, t9, t10, t11); } }
public void QueueFunc <T1, T2, T3, R>(MyFunc <T1, T2, T3, R> action, T1 t1, T2 t2, T3 t3) { bool needUseLambda = true; ObjectPool <PoolAllocatedFunc <T1, T2, T3, R> > pool; m_ActionPools.GetOrNewData(out pool); if (null != pool) { PoolAllocatedFunc <T1, T2, T3, R> helper = pool.Alloc(); if (null != helper) { helper.SetPoolRecycleLock(m_LockForAsyncActionRun); helper.Init(action, t1, t2, t3); m_Actions.Enqueue(helper.Run); needUseLambda = false; } } if (needUseLambda) { m_Actions.Enqueue(() => { action(t1, t2, t3); }); LogSystem.Warn("QueueAction {0}({1},{2},{3}) use lambda expression, maybe out of memory.", action.Method.ToString(), t1, t2, t3); } }