运行任意数量的函数,每个函数在自己的线程上运行

本文关键字:函数 运行 自己的 线程 任意数 | 更新日期: 2023-09-27 17:51:16

在并行运行的对象集合上执行相同函数的最有效方法是什么?我知道我可以把new Thread(() => MyFunc(myParam)).Start()放在循环中,但是有没有更好的方法?这似乎是一种非常丑陋的方式。

运行任意数量的函数,每个函数在自己的线程上运行

[…有没有更好的办法?这似乎是一种非常丑陋的方式。

是的,这是一种非常丑陋和低效的方法。每个线程将消耗大量资源,但您的计算机只能同时执行N个线程,其中N是计算机上的CPU核数。因此,你可以在优化线程数量以适应CPU内核数量的库的基础上构建,而不是使用像线程这样的低级原语。

在你有一个对象集合的情况下,我建议:

    并行LINQ
  • Parallel.ForEach
  • Parallel.For

LINQ代码:

var result = source.Select(item => ...).ToList();

Parallel LINQ code:

var result = source.AsParallel().Select(item => ...).ToList();

对于每个循环:

foreach (var item in source)
  Process(item);

每个循环并行:

Parallel.ForEach(
  source,
  item => Process(item);
);
循环:

for (var i = 0; i < list.Count; i += 1)
  list[i] = Process(list[i]);

平行for循环:

Parallel.For(
  0,
  list.Count,
  i => {
    list[i] = Process(list[i]);
  }
);

您可以从。net 4.0开始使用Parallel.ForParallel.ForeachParallel.Invoke

从。net 4.0开始,在代码中直接使用Thread的理由很少。您可以使用TPL,这是实现任务并行性或数据并行性的推荐方法。

引用Stephen Cleary的书

只要你输入new Thread(),它就结束了;你的项目已经遗留代码