我有一个任务,它运行一个循环并延迟每次迭代的间隔.一旦CancellationTokenSource调用Cancel(),我希望我的主代码Wait()为Task.Delay(间隔)完成,任务在我的代码继续之前退出循环.我认为这段代码可行,但事实并非如此.
相反,我的主代码在循环退出之前传递t.Wait().为什么?
var cts = new CancellationTokenSource(); CancellationToken ct = cts.Token; var t = Task.Run(() => { MyLoopTask(200,ct); }); // Prepare information cts.Cancel(); t.Wait(); // Send Information
任务代码
private async Task MyLoopTask(int interval,CancellationToken cancelToken) { while (!cancelToken.IsCancellationRequested) { Debug.Print(" Still In Loop "); // Do something await Task.Delay(interval); } Debug.Print(" cancelled "); //Clean up }
解决方法
您使用Task.Run创建一个任务,该任务会触发并忘记您从MyLoopTask返回的实际任务.
Task.Run在这里是多余的.您可以调用MyLoopTask并使用它返回的任务.
var t = MyLoopTask(200,ct); // ... t.Wait();
如果您仍有某些理由使用Task.Run,您可以通过确保委托等待实际任务来执行此操作:
var t = Task.Run(async () => await MyLoopTask(200,ct)); // ... t.Wait();