首頁 >後端開發 >C++ >如何在C#中限制並發任務?

如何在C#中限制並發任務?

Mary-Kate Olsen
Mary-Kate Olsen原創
2024-12-29 04:08:10475瀏覽

How to Limit Concurrent Tasks in C#?

C# 中限制並發任務

在多執行緒和非同步程式設計中,控制並行任務的數量可以增強效能並保持穩定性。本題探討如何在 C# 中限制最大並發任務數。

限制並發

提供的程式碼區塊舉例說明了為每個輸入訊息建立一個新任務。如果訊息計數很大,此方法可能會導致資源利用率過高。要限制並發,請考慮使用 Parallel.ForEach 和 MaxDegreeOfParallelism。

Parallel.ForEach(messages, new ParallelOptions { MaxDegreeOfParallelism = 10},
msg =>
{
     // logic
     Process(msg);
});

透過將 MaxDegreeOfParallelism 指定為 10,最多可以同時處理 10 則訊息,從而減少資源壓力。

維護序列

但是,這種方法不能保證按照與原始集合相同的順序處理訊息。為了確保順序​​,請使用 Parallel LINQ 庫中的 SequentialQuery:

var processedMessages = messages.AsParallel()
    .AsOrdered()  // Preserves order
    .Select(msg => Process(msg))
    .ToList(); // Forces execution

這可確保訊息按照與輸入集合相同的順序進行處理,同時仍利用並行性來提高效率。

以上是如何在C#中限制並發任務?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn