溫馨提示×

如何控制C# Parallel.ForEach的并發度

c#
小樊
173
2024-10-09 12:45:42
欄目: 編程語言

在C#中,可以使用Parallel.ForEach方法來并行處理集合中的元素。要控制Parallel.ForEach的并發度,可以通過設置ParallelOptions對象來實現。以下是一個示例:

using System;
using System.Collections.Generic;
using System.Threading;
using System.Threading.Tasks;

class Program
{
    static void Main()
    {
        List<int> numbers = new List<int> { 1, 2, 3, 4, 5, 6, 7, 8, 9 };

        // 創建一個ParallelOptions對象
        ParallelOptions options = new ParallelOptions();

        // 設置最大并行度(這里設置為4)
        options.MaxDegreeOfParallelism = 4;

        // 使用Parallel.ForEach處理集合中的元素
        Parallel.ForEach(numbers, options, (number, state, index) =>
        {
            Console.WriteLine($"Processing {number} at index {index}");
            Thread.Sleep(100); // 模擬耗時操作
        });

        Console.WriteLine("All tasks completed.");
    }
}

在這個示例中,我們創建了一個ParallelOptions對象,并通過MaxDegreeOfParallelism屬性設置了最大并行度為4。這意味著Parallel.ForEach將同時處理最多4個元素。請注意,實際并發度可能會受到系統資源和任務性質的影響。

0
亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女