我需要并行化一个方法,对列表中的元素进行穷尽的成对比较。串行实现很直接:
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);
});
});
使用并行任务库,最理想的实现方式是什么?