Parallel.ForEach是否需要AsParallel()?

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (1)
  • 关注 (0)
  • 查看 (86)

ParallelEnumerable有一个静态成员AsParallel。如果我有一个IEnumerable<T>和想要使用Parallel.ForEach这是否意味着我应该总是使用AsParallel

这两个都是正确的?

没有AsParallel

List<string> list = new List<string>();
Parallel.ForEach<string>(GetFileList().Where(file => reader.Match(file)), f => list.Add(f));

AsParallel

List<string> list = new List<string>();
Parallel.ForEach<string>(GetFileList().Where(file => reader.Match(file)).AsParallel(), f => list.Add(f));
提问于
用户回答回答于

这取决于被称为什么,他们是不同的问题。

.AsParallel()并行枚举

Parallel.ForEach并行化循环

所属标签

可能回答问题的人

  • 嗨喽你好

    7 粉丝480 提问9 回答
  • 富有想象力的人

    3 粉丝0 提问7 回答
  • uncle_light

    5 粉丝518 提问6 回答
  • 人生的旅途

    10 粉丝484 提问6 回答

扫码关注云+社区

领取腾讯云代金券