C#中的Task.WhenAll()和Task.WaitAll()有什么区别?
Task.WaitAll阻止当前线程,直到所有其他任务完成执行为止。Task.WhenAll方法用于创建仅当所有其他任务均已完成时才完成的任务。
如果我们使用Task.WhenAll,我们将得到一个未完成的任务对象。但是,它不会阻塞,但会允许程序执行。相反,Task.WaitAll方法调用实际上会阻塞并等待所有其他任务完成。
为了举例说明,让我们说我们有一个任务,它使用UI线程执行一些活动,例如需要在用户界面中显示一些动画。现在,如果我们使用Task.WaitAll,则在所有相关任务完成并释放该块之前,该用户界面将被阻止并且不会更新。但是,如果我们在同一应用程序中使用Task.WhenAll,则不会阻塞UI线程,而是会照常更新。
Task.WhenAll的示例-
示例
using System;using System.Threading.Tasks;
namespace DemoApplication{
public class Program{
static void Main(string[] args){
Task task1 = new Task(() =>{
for (int i = 0; i < 5; i++){
Console.WriteLine("Task 1 - iteration {0}", i);
Task.Delay(1000);
}
Console.WriteLine("Task 1 complete");
});
Task task2 = new Task(() =>{
Console.WriteLine("Task 2 complete");
});
task1.Start();
task2.Start();
Console.WriteLine("等待任务完成。");
Task.WhenAll(task1, task2);
Console.WriteLine("任务完成。");
Console.ReadLine();
}
}
}
输出结果
上面代码的输出是
等待任务完成。任务完成。
Task 1 - iteration 0
Task 2 complete
Task 1 - iteration 1
Task 1 - iteration 2
Task 1 - iteration 3
Task 1 - iteration 4
Task 1 complete
在上面的示例中,我们可以看到在使用Task.WhenAll时,在其他任务完成之前执行了complete任务。这意味着Task.WhenAll不会阻止执行。
Task.WaitAll的示例-
示例
using System;using System.Threading.Tasks;
namespace DemoApplication{
public class Program{
static void Main(string[] args){
Task task1 = new Task(() =>{
for (int i = 0; i < 5; i++){
Console.WriteLine("Task 1 - iteration {0}", i);
Task.Delay(1000);
}
Console.WriteLine("Task 1 complete");
});
Task task2 = new Task(() =>{
Console.WriteLine("Task 2 complete");
});
task1.Start();
task2.Start();
Console.WriteLine("等待任务完成。");
Task.WaitAll(task1, task2);
Console.WriteLine("任务完成。");
Console.ReadLine();
}
}
}
输出结果
上面代码的输出是
等待任务完成。Task 1 - iteration 0
Task 2 complete
Task 1 - iteration 1
Task 1 - iteration 2
Task 1 - iteration 3
Task 1 - iteration 4
Task 1 complete
任务完成。
在上面的示例中,我们可以看到,使用Task.WaitAll时,仅在所有其他任务完成后才执行完成任务。这意味着Task.WaitAll阻止执行。
以上是 C#中的Task.WhenAll()和Task.WaitAll()有什么区别? 的全部内容, 来源链接: utcz.com/z/316254.html