我有一个任务,它运行一个循环并延迟每次迭代的间隔.一旦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 }
解决方法
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。