Parallel.ForEach 使用多线遍历循环

Posted personblog

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Parallel.ForEach 使用多线遍历循环相关的知识,希望对你有一定的参考价值。

  Parallel.ForEach相对于foreach是多线程,并行操作;foreach是单线程品德操作。

  static void Main(string[] args)
        {
            Console.WriteLine("Hello World!");
            List<UserInfo> lst = new List<UserInfo> { };
            UserInfo[] array = new UserInfo[] {};
            for (int i = 1; i <= 10; i++)
            {
                lst.Add(new UserInfo { Age=new Random().Next(1,10),Id=Guid.NewGuid()});
            }
            foreach (var item in lst)
            {
                Console.WriteLine("循环更改前的值:"+item.Id+","+item.Age+","+item.Uname);
            }
            array = lst.ToArray();
            //注意Parallel.ForEach 里面传的是数组, MaxDegreeOfParallelism = Environment.ProcessorCount指的是系统有几个cpu就使用几个cpu
            ParallelLoopResult result = Parallel.ForEach(array, new ParallelOptions { MaxDegreeOfParallelism = Environment.ProcessorCount },item =>
            {
                item.Uname = "" + item.Age;
              
            });
            foreach (var item in array)
            {
                Console.WriteLine("循环更改后的值:" + item.Id + "," + item.Age + "," + item.Uname);
            }
            Console.ReadKey();
        }
  public class UserInfo
    {
        public Guid Id { get; set; }

        public Int32 Age { get; set; }

        public String Uname { get; set; }
    }

 

以上是关于Parallel.ForEach 使用多线遍历循环的主要内容,如果未能解决你的问题,请参考以下文章

带有 BlockingCollection.GetConsumableEnumerable 的 Parallel.ForEach 循环

为啥覆盖 Parallel.foreach 循环的 .NET 单元测试依赖于硬件?

在 parallel.ForEach 循环中获取线程 ID

C#的并发循环(for,foreach,parallel.for,parallel.foreach)对比

.Net 中的多个 Parallel.ForEach 循环

我在 Parallel.ForEach 循环中收到 TaskCanceledException,如何解决?