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