繁体   English   中英

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

[英]Run any number of functions, each on their own thread

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

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

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

如果您有一组对象,我建议:

LINQ代码:

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

并行LINQ代码:

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]);

并行循环:

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

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

没有理由直接在.Net4.0开始的代码中使用Thread 您可以使用TPL,这是实现任务并行或数据并行的推荐方法。

引用Stephen Cleary 的书

一旦你键入new Thread() ,它就结束了; 您的项目已有遗留代码

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM