首页 > 解决方案 > 我对 Parallel.ForEach 做错了什么

问题描述

我在 C# 中有以下带有 Parallel.ForEach 的代码

internal class Program
{
    private static void Main(string[] args)
    {
        var recordList = new List<string> {"1", "two", "three", "four", "five", "six"};

        var result = new ConcurrentBag<ProcessedData>();

        Parallel.ForEach<string, ProcessedData>(recordList, () => null //local init
            , (record, state, index, localInit) => //body
            {
                Console.WriteLine($"Processing {record}");
                var integerValue = record.Length;
                var processedString = record + " Processed";

                localInit = new ProcessedData
                {
                    IntegerValue = integerValue,
                    StringValue = processedString
                };

                return localInit;
            }, bodyResult => //local finally
            {
                Console.WriteLine($"Adding {bodyResult.StringValue}");
                result.Add(bodyResult);
            });


        foreach (var item in result)
        {
            Console.WriteLine($"{item.StringValue}");
        }

        Console.ReadLine();
    }

    private sealed class ProcessedData
    {
        internal int IntegerValue { get; set; }
        internal string StringValue { get; set; }
    }

当我运行程序时,我希望控制台打印出“1已处理”,“2已处理”,“3已处理”,“4已处理”,“5已处理”,“6已处理”。但是,只有一些项目有已处理!!!

在此处输入图像描述

你知道代码出了什么问题吗?

标签: c#.netparallel.foreach

解决方案


finally 不会对集合中的每个项目运行该操作。如果您想对集合中的每个项目执行一些操作,这就是 body 的用途。init 和 finally 用于初始化和拆除每个工作线程。因此,您的打印输出告诉您在处理您的项目时使用了三个线程。


推荐阅读