【发布时间】:2010-07-19 13:46:40
【问题描述】:
我需要并行化一个对列表中的元素进行详尽的成对比较的方法。串行实现很简单:
foreach (var element1 in list)
foreach (var element2 in list)
foo(element1, element2);
在这种情况下,foo 不会改变 element1 或 element2 的状态。我知道简单地做嵌套的 Parallel.ForEach 语句是不安全的:
Parallel.ForEach(list, delegate(A element1)
{
Parallel.ForEach(list, delegate(A element2)
{
foo(element1, element2);
});
});
使用并行任务库实现这一点的理想方法是什么?
【问题讨论】:
标签: c# parallel-processing task-parallel-library