using Serein.Library.Api; using Serein.Library.Utils; using System; using System.Security.Claims; using System.Threading.Tasks; namespace Serein.Library.Framework.NodeFlow { /// /// 动态流程上下文 /// public class DynamicContext : IDynamicContext { public DynamicContext(/*ISereinIOC sereinIoc,*/ IFlowEnvironment flowEnvironment) { // SereinIoc = sereinIoc; Env = flowEnvironment; } public NodeRunCts NodeRunCts { get; set; } // public ISereinIOC SereinIoc { get; } public IFlowEnvironment Env { get; } public Task CreateTimingTask(Action action, int time = 100, int count = -1) { if(NodeRunCts == null) { NodeRunCts = Env.IOC.GetOrRegisterInstantiate(); } // 使用局部变量,避免捕获外部的 `action` Action localAction = action; return Task.Run(async () => { for (int i = 0; i < count && !NodeRunCts.IsCancellationRequested; i++) { await Task.Delay(time); if (NodeRunCts.IsCancellationRequested) { break; } //if (FlowEnvironment.IsGlobalInterrupt) //{ // await FlowEnvironment.GetOrCreateGlobalInterruptAsync(); //} // 确保对局部变量的引用 localAction?.Invoke(); } // 清理引用,避免闭包导致的内存泄漏 localAction = null; }); } } }