首页 > 学院 > 开发设计 > 正文

Parallel与PLINQ简单示例

2019-11-14 14:12:22
字体:
来源:转载
供稿:网友

    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,否则不能使用。


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表