private void TaskUpdate(float deltaTime) { MDebug.Assert(m_TaskItemsCache.Count == 0, "Core", "m_TaskItemsCache.Count == 0"); for (int iBehaviour = 0; iBehaviour < m_BehavioursForTraverse.Count; iBehaviour++) { BaseBehaviour iterBehaviour = m_BehavioursForTraverse[iBehaviour]; if (!iterBehaviour.CanUpdate() || !iterBehaviour.HasFeature(FeatureFlag.TaskUpdate)) { continue; } TaskUpdateItem iterTaskItem = m_TaskItemPool.Alloc() .SetData(iterBehaviour, deltaTime); m_TaskItemsCache.Add(iterTaskItem); try { MDebug.LogVerbose("Core" , $"Before execute {iterBehaviour.GetName()}.OnBeforeTastUpdate"); iterTaskItem.Input = iterBehaviour.OnBeforeTastUpdate(); MDebug.LogVerbose("Core" , $"After execute {iterBehaviour.GetName()}.OnBeforeTastUpdate"); } catch (Exception e) { MDebug.LogError("Core" , $"Execute {iterBehaviour.GetName()}.OnBeforeTastUpdate Exception:{e.ToString()}"); } System.Threading.ThreadPool.QueueUserWorkItem(iterBehaviour.DoTaskUpdate_Thread, iterTaskItem); } }