我需要并行化一种方法,该方法对列表中的元素进行详尽的成对比较。串行实现很简单:
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);
});
});
使用并行任务库实现这一点的理想方法是什么?