簡體   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