一、Parallel类

Parallel类提供了数据和任务的并行性;

二、Paraller.For()

Paraller.For()方法类似于C#的for循环语句,也是多次执行一个任务。使用Paraller.For()方法,可以并行运行迭代,迭代的顺序没有定义。

在For()方法中,前两个参数是固定的,这两个参数定义了循环的开头和结束。首先描述它的第一个方法For(int,int,Action<int>),前面两个参数代表循环的开头和介绍,第三个参数是个委托,整数参数是循环的迭代次数,该参数被传递给委托引用的方法。Paraller.For()方法的返回类型是ParallelLoopResult结构,它提供了循环是否结束的信息和最低迭代的索引(返回一个表示从中调用 Break 语句的最低迭代的整数)。先写个例子:

            ParallelLoopResult result = Parallel.For(0, 10, i =>{Console.WriteLine("迭代次数:{0},任务ID:{1},线程ID:{2}", i, Task.CurrentId, Thread.CurrentThread.ManagedThreadId);Thread.Sleep(10);});Console.WriteLine("是否完成:{0}", result.IsCompleted);Console.WriteLine("最低迭代:{0}", result.LowestBreakIteration);

输出结果如下:

可以看到,该委托方法运行了10次,顺序也是不能被保证的。但是最低迭代并没有数据出来,这是因为他是返回调用 Break 语句的最低迭代的整数,在这我们并没有break。如果需要才执行过程中提前中断For()方法,就可以使用ParallelLoopState来实现,For(int,int,Action<int,ParallelLoopState>)。就上面的例子改一下:

            ParallelLoopResult result = Parallel.For(0, 10, (i, state) =>{Console.WriteLine("迭代次数:{0},任务ID:{1},线程ID:{2}", i, Task.CurrentId, Thread.CurrentThread.ManagedThreadId);Thread.Sleep(10);if (i > 5)state.Break();});Console.WriteLine("是否完成:{0}", result.IsCompleted);Console.WriteLine("最低迭代:{0}", result.LowestBreakIteration);

输出结果如下:

三、Parallel.ForEach()

Paraller.ForEach()方法遍历实现了IEnumerable的集合,其方法类似于 foreach的语句,但以异步方式遍历,这里也没有确定遍历顺序。首先描述它的第一个方法,Paraller.ForEach<TSource>(IEnumerable<TSource>,Action<TSource>),先看下面的例子;

            string[] data = { "str1", "str2", "str3" };ParallelLoopResult result = Parallel.ForEach<string>(data, str =>{Console.WriteLine(str);});Console.WriteLine("是否完成:{0}", result.IsCompleted);Console.WriteLine("最低迭代:{0}", result.LowestBreakIteration);

输出结果如下:

它也可以像For一样传入迭代次数和ParallelLoopState的,方法是ForEach<TSource>(IEnumerable<TSource> source, Action<TSource, ParallelLoopState, long> body),接着在上面的例子改动

            string[] data = { "str1", "str2", "str3", "str4", "str5" };ParallelLoopResult result = Parallel.ForEach<string>(data, (str, state, i) =>{Console.WriteLine("迭代次数:{0},{1}", i, str);if (i > 3)state.Break();});Console.WriteLine("是否完成:{0}", result.IsCompleted);Console.WriteLine("最低迭代:{0}", result.LowestBreakIteration);

输出结果如下:

四、Parallel.Invoke()

Parallel.Invoke()方法,它提供了任务并行性模式。Paraller.Invoke()方法允许传递一个Action委托数组,在其中可以指定应运行的方法,看下面的例子

            Parallel.Invoke(() =>{Thread.Sleep(100);Console.WriteLine("method1");}, () =>{Thread.Sleep(10);Console.WriteLine("method2");});

输出结果如下:

五、结语

Parallel.For()和Paraller.ForEach()方法在每次迭代中调用相同的代码,而Parallel.Invoke()方法允许同时调用不同的方法。Parallel.ForEach()用于数据并行性,Parallel.Invoke()用于任务并行性;

转载于:https://www.cnblogs.com/ricky-wang/p/7003162.html

C# 并行任务——Parallel类相关推荐

  1. 第九节:深究并行编程Parallel类中的三大方法 (For、ForEach、Invoke)和几大编程模型(SPM、APM、EAP、TAP)

    一. 并行编程 1. 区分串行编程和串行编程 ①. 串行编程:所谓的串行编程就是单线程的作用下,按顺序执行.(典型代表for循环 下面例子从1-100按顺序执行) ②. 并行编程:充分利用多核cpu的 ...

  2. 深究并行编程Parallel类中的三大方法 (For、ForEach、Invoke)和几大编程模型(SPM、APM、EAP、TAP)

    一. 并行编程 1. 区分串行编程和串行编程 ①. 串行编程:所谓的串行编程就是单线程的作用下,按顺序执行.(典型代表for循环 下面例子从1-100按顺序执行) ②. 并行编程:充分利用多核cpu的 ...

  3. [深入学习C#]C#实现多线程的方式:使用Parallel类

    简介 在C#中实现多线程的另一个方式是使用Parallel类.  在.NET4中 ,另一个新增的抽象线程是Parallel类 .这个类定义了并行的for和foreach的 静态方法.在为 for和 f ...

  4. 抽象线程之Parallel类

    该类定义了并行的For和Foreach方法,Parallel类使用多个任务,因此需要多个线程来完成这个作业 代码及简单注释如下: using System; using System.Collecti ...

  5. 【.Net】C#实现多线程的方式:使用Parallel类

    简介 在C#中实现多线程的另一个方式是使用Parallel类.  在.NET4中 ,另一个新增的抽象线程是Parallel类 .这个类定义了并行的for和foreach的 静态方法.在为 for和 f ...

  6. C#编程,Parallel类实现数据并行与任务并行

    一.Parallel类 Parallel类提供了数据和任务的并行性: 二.Paraller.For() Paraller.For()方法类似于C#的for循环语句,也是多次执行一个任务.使用Paral ...

  7. C#并行开发_Thread/ThreadPool, Task/TaskFactory, Parallel

    大家好,本次讨论的是C#中的并行开发,给力吧,随着并行的概念深入,哥也赶上这个潮流了,其实之前讨论C#的异步调用或者C#中BeginInvoke或者Invoke都已经涉及了部分本篇的内容. 参考书目: ...

  8. Parallel并行计算合计数据时错误的原因和解决办法

    在.NET 4.0中System.Threading.Tasks.Parallel类中有几个很方便调用的并行计算方法,我想各位会经常用到Parallel.For,Parallel.ForEach,正常 ...

  9. 转载 Net多线程编程—System.Threading.Tasks.Parallel

    .Net多线程编程-System.Threading.Tasks.Parallel System.Threading.Tasks.Parallel类提供了Parallel.Invoke,Paralle ...

最新文章

  1. 50强人工智能面试问题与解答
  2. 利用sql报错帮助进行sql注入
  3. 天锐绿盾解密_天锐绿盾携手衡阳规划设计院 实现信息系统安全管理
  4. Codeforces 997E Good Subsegments (线段树)
  5. boost::fruchterman_reingold_force_directed_layout用法的测试程序
  6. JAVA听力源码,英语听力练习
  7. python中时间模块
  8. 分布式事务Seata的AT模式下两阶段提交原理
  9. (转) Arcgis for js之WKT和GEOMETRY的相互转换
  10. tensorflow画损失函数的代码_使用TensorFlow编写您的第一个神经网络
  11. 调用阿里API创建阿里云主机
  12. 3种顺序排序方法。简单排序是指时间复杂度为O(n^2)的排序方法。
  13. 苹果支付IAP V1
  14. USB OTG(Host) 、 USB ADB(Device)、DWC3 Charge
  15. 小白有这六个Python学习网站,比那些收费几百几千的还要好用
  16. Java面试问题总结归纳
  17. 程序人生之九:2012,回首这7年
  18. 大学生实习就业调研报告:8个共性问题与企业CTO/CEO/HR管理者探讨
  19. 将PPT转化为长图(长截图)【Python方法】
  20. 利用python 绘制有效边界efficient frontier

热门文章

  1. python简单代码编写-新手写Python,8招让你的代码更简洁更Pythonic!
  2. 合肥python培训-合肥Python测试开发全栈核心课程
  3. python输出数据到excel-Python从数据库导出数据到Excel
  4. python安装pip-Python2.7.5安装pip9.0.1
  5. python爬虫新手项目-给新手推荐几个实用又适合上手的Python爬虫项目
  6. Mybatis的解析模块基础
  7. HDU2076 夹角有多大
  8. VoIP应用系统大盘点
  9. python -- IO多路复用
  10. cocos lua 创建替换图片