在具有資源約束的 Parallel.ForEach() 中管理並發任務
在使用並行循環時,其中各個操作受到資源限制(例如網路頻寬或 API 速率限制),控制並發層級至關重要。 Parallel.ForEach()
方法與 ParallelOptions
類別結合使用,提供了一個簡單的解決方案。
ParallelOptions
類別提供 MaxDegreeOfParallelism
屬性,該屬性設定允許並發執行的最大執行緒數。 這有效地限制了同時操作的數量,防止資源過載。
考慮一個網頁抓取場景,其中網路頻寬將並發下載限制為一次四個。 以下程式碼片段示範如何強制執行此限制:
<code class="language-csharp">Parallel.ForEach( listOfWebpages, new ParallelOptions { MaxDegreeOfParallelism = 4 }, webpage => { DownloadWebpage(webpage); } );</code>
將 MaxDegreeOfParallelism
設定為 4 可確保最多四個執行緒同時下載網頁,從而遵守頻寬限制。
進一步閱讀:
以上是如何限制 Parallel.ForEach() 中的並行性以進行節流操作?的詳細內容。更多資訊請關注PHP中文網其他相關文章!