微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – 为什么在我的代码通过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();

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐