gpt4 book ai didi

c# - Task.WaitAll 不等待任务完成

转载 作者:可可西里 更新时间:2023-11-01 07:51:13 26 4
gpt4 key购买 nike

在尝试弄清楚 C# 中的新(现在可能不是那么新,但对我来说还是新的)Task 异步编程时,我遇到了一个问题,我花了一些时间才弄明白,我不确定为什么。

我已经解决了这个问题,但我仍然不确定为什么它是一个问题。我只是想我会分享我的经验,以防有人遇到同样的情况。

如果有任何专家愿意告诉我问题的原因,那将是非常好的,我们将不胜感激。我总是喜欢知道为什么某些东西不起作用!

我做了一个测试任务,如下:

Random rng = new Random((int)DateTime.UtcNow.Ticks);
int delay = rng.Next(1500, 15000);
Task<Task<object>> testTask = Task.Factory.StartNew<Task<object>>(
async (obj) =>
{
DateTime startTime = DateTime.Now;
Console.WriteLine("{0} - Starting test task with delay of {1}ms.", DateTime.Now.ToString("h:mm:ss.ffff"), (int)obj);
await Task.Delay((int)obj);
Console.WriteLine("{0} - Test task finished after {1}ms.", DateTime.Now.ToString("h:mm:ss.ffff"), (DateTime.Now - startTime).TotalMilliseconds);
return obj;
},
delay
);
Task<Task<object>>[] tasks = new Task<Task<object>>[] { testTask };

Task.WaitAll(tasks);
Console.WriteLine("{0} - Finished waiting.", DateTime.Now.ToString("h:mm:ss.ffff"));

// make console stay open till user presses enter
Console.ReadLine();

然后我运行该应用程序以查看它吐出的内容。这是一些示例输出:

6:06:15.5661 - Starting test task with delay of 3053ms.
6:06:15.5662 - Finished waiting.
6:06:18.5743 - Test task finished after 3063.235ms.

如您所见,Task.WaitAll(tasks); 语句没有做太多事情。在继续执行之前总共等待了 1 毫秒。

我已经在下面回答了我自己的“问题”——但正如我上面所说的——如果有比我更了解的人愿意解释为什么这不起作用,请做!(我认为一旦到达await运算符,它可能与方法的执行“退出”有关 - 然后在等待完成后退回...但我可能错了)

最佳答案

你应该避免使用 Task.Factory.StartNew使用异步等待。你应该使用 Task.Run相反。

异步方法返回 Task<T> ,异步委托(delegate)也是如此。 Task.Factory.StartNew还返回 Task<T> ,其结果是委托(delegate)参数的结果。所以当一起使用时,它返回一个 Task<Task<T>>> .

这一切 Task<Task<T>>做的是执行委托(delegate),直到有一个任务要返回,也就是到达第一个 await 时。如果您只等待该任务完成,您就不会等待整个方法,而只是等待第一个 await 之前的部分。

您可以使用 Task.Unwrap 来解决这个问题这会创建一个 Task<T>那代表那Task<Task<T>>> :

Task<Task> wrapperTask = Task.Factory.StartNew(...);
Task actualTask = wrapperTask.Unwrap();
Task.WaitAll(actualTask);

关于c# - Task.WaitAll 不等待任务完成,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32156195/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com