运行任意数量的函数,每个函数在自己的线程上运行
本文关键字:函数 运行 自己的 线程 任意数 | 更新日期: 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.For
或Parallel.Foreach
或Parallel.Invoke
。
从。net 4.0开始,在代码中直接使用Thread
的理由很少。您可以使用TPL,这是实现任务并行性或数据并行性的推荐方法。
引用Stephen Cleary的书
只要你输入
new Thread()
,它就结束了;你的项目已经遗留代码