微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – 同一列表中嵌套的Parallel.ForEach循环?

我需要并行化一个方法,对列表中的元素进行详尽的成对比较.串行实现是直接的:
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);
    });
});

使用并行任务库实现这一目标的理想方法是什么?

解决方法

你不能只有一个平行和一个正常循环吗?所以也是
Parallel.ForEach(list,delegate(A element1)
{
  foreach(A element2 in list)
    foo(element1,element2)
});

要么

foreach(A element1 in list)
{
  Parallel.ForEach(list,delegate(A element2)
  {
    foo(element1,element2);
  });
}

应该加快速度.每个循环都不会有一个线程,所以这可能与嵌套的并行循环一样快或稍慢.

原文地址:https://www.jb51.cc/csharp/93655.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐