我有一个任务,它运行一个循环并延迟每次迭代的间隔.一旦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 }