程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> C# >> C#入門知識 >> Parallel與PLINQ簡單示例,parallelplinq

Parallel與PLINQ簡單示例,parallelplinq

編輯:C#入門知識

Parallel與PLINQ簡單示例,parallelplinq


    Parallel是對Task用法的簡化,含有Parallel.For、Parallel.ForEach、Parallel.Invoke三個靜態方法。PLINQ是並行版本的LINQ。下面給出Parallel和PLINQ的簡單示例及注意事項。

    一、簡單示例

    1、Parallel.For

            int[] nums = new[] { 1, 2, 3, 4 };
            Parallel.For(0, nums.Length, i =>
            {
                Console.WriteLine("下標:{0},值:{1}", i, nums[i]);
            });

    2、Parallel.ForEach

            var ltModel = new List<UserInfo>();
            for (int i = 1; i <= 5; i++)
            {
                var item = new UserInfo { No = i, Name = "名字" + i };
                ltModel.Add(item);
            }
            Parallel.ForEach(ltModel, item =>
            {
                Console.WriteLine("No:{0}, Name:{1}", item.No, item.Name);
            });

    3、Parallel.Invoke

            var ltTask = new List<Action>();
            for (int i = 1; i <= 5; i++)
            {
                int j = i;
                ltTask.Add(() =>
                {
                    Console.WriteLine("啟動任務" + j);
                });
            }
            Parallel.Invoke(ltTask.ToArray());

    4、PLINQ

            var ltNum = new List<int>() {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
            var resultNum = (from n in ltNum.AsParallel() where n>=3 orderby n descending select n).ToArray();
            foreach (var item in resultNum)
            {
                Console.WriteLine("Num: {0}", item);   
            }

    二、注意事項

    如果對集合的邏輯順序沒有要求,可以用Parallel和PLINQ,否則不能使用。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved