c# – 为什么在我的代码通过Wait命令之前,此任务未完成
发布时间:2020-12-15 08:17:05 所属栏目:百科 来源:网络整理
导读:我有一个任务,它运行一个循环并延迟每次迭代的间隔.一旦CancellationTokenSource调用Cancel(),我希望我的主代码Wait()为Task.Delay(间隔)完成,任务在我的代码继续之前退出循环.我认为这段代码可行,但事实并非如此. 相反,我的主代码在循环退出之前传递t.Wait(
我有一个任务,它运行一个循环并延迟每次迭代的间隔.一旦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(); (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |