C#TPL如何知道所有任务都完成了?

时间:2011-02-21 14:55:55

标签: c# task task-parallel-library

我有Loop生成任务。

代码:

Task task = null;
foreach (Entity a in AAAA)
{
  // create the task 
  task = new Task(() => {
    myMethod(a);
  },  Token, TaskCreationOptions.None);
  task.Start();
}

正如您在每次迭代中看到的那样,任务对象具有新的初始化(.. new Task(()=> ..)     我怎么知道所有的任务都完成了?

3 个答案:

答案 0 :(得分:23)

我用

替换它
 Parallel.ForEach(...,  () => myMethod(a), ...)

然后你会在ForEach结束时自动等待所有任务。

也许可以从单独的任务中运行ForEach。

答案 1 :(得分:13)

var allTasks = new List<Task>();
foreach (Entity a in AAAA)
{
  // create the task 
  task = new Task(() => {
    myMethod(a);
  },  Token, TaskCreationOptions.None);

  // Add the tasks to a list
  allTasks.Add(task);
  task.Start();
}

// Wait until all tasks are completed.
Task.WaitAll(allTasks.ToArray());

答案 2 :(得分:8)

您需要保留对循环中创建的所有任务的引用。然后,您可以使用Task.WaitAll方法(请参阅MSDN reference)。您可以创建一个数组并将任务分配给数组的元素(在C#2.0中),也可以使用LINQ:

var tasks = 
   AAAA.Select((Entity a) => 
      Task.Factory.StartNew(() => { myMethod(a); },
         Token, TaskCreationOptions.None)).ToArray();
Task.WaitAll(tasks)

如果您不需要(明确地)使用任务,那么Henk建议使用Parallel.ForEach可能是更好的选择。