C# 并行任务——Parallel类
一、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类相关推荐
- 第九节:深究并行编程Parallel类中的三大方法 (For、ForEach、Invoke)和几大编程模型(SPM、APM、EAP、TAP)
一. 并行编程 1. 区分串行编程和串行编程 ①. 串行编程:所谓的串行编程就是单线程的作用下,按顺序执行.(典型代表for循环 下面例子从1-100按顺序执行) ②. 并行编程:充分利用多核cpu的 ...
- 深究并行编程Parallel类中的三大方法 (For、ForEach、Invoke)和几大编程模型(SPM、APM、EAP、TAP)
一. 并行编程 1. 区分串行编程和串行编程 ①. 串行编程:所谓的串行编程就是单线程的作用下,按顺序执行.(典型代表for循环 下面例子从1-100按顺序执行) ②. 并行编程:充分利用多核cpu的 ...
- [深入学习C#]C#实现多线程的方式:使用Parallel类
简介 在C#中实现多线程的另一个方式是使用Parallel类. 在.NET4中 ,另一个新增的抽象线程是Parallel类 .这个类定义了并行的for和foreach的 静态方法.在为 for和 f ...
- 抽象线程之Parallel类
该类定义了并行的For和Foreach方法,Parallel类使用多个任务,因此需要多个线程来完成这个作业 代码及简单注释如下: using System; using System.Collecti ...
- 【.Net】C#实现多线程的方式:使用Parallel类
简介 在C#中实现多线程的另一个方式是使用Parallel类. 在.NET4中 ,另一个新增的抽象线程是Parallel类 .这个类定义了并行的for和foreach的 静态方法.在为 for和 f ...
- C#编程,Parallel类实现数据并行与任务并行
一.Parallel类 Parallel类提供了数据和任务的并行性: 二.Paraller.For() Paraller.For()方法类似于C#的for循环语句,也是多次执行一个任务.使用Paral ...
- C#并行开发_Thread/ThreadPool, Task/TaskFactory, Parallel
大家好,本次讨论的是C#中的并行开发,给力吧,随着并行的概念深入,哥也赶上这个潮流了,其实之前讨论C#的异步调用或者C#中BeginInvoke或者Invoke都已经涉及了部分本篇的内容. 参考书目: ...
- Parallel并行计算合计数据时错误的原因和解决办法
在.NET 4.0中System.Threading.Tasks.Parallel类中有几个很方便调用的并行计算方法,我想各位会经常用到Parallel.For,Parallel.ForEach,正常 ...
- 转载 Net多线程编程—System.Threading.Tasks.Parallel
.Net多线程编程-System.Threading.Tasks.Parallel System.Threading.Tasks.Parallel类提供了Parallel.Invoke,Paralle ...
最新文章
- 50强人工智能面试问题与解答
- 利用sql报错帮助进行sql注入
- 天锐绿盾解密_天锐绿盾携手衡阳规划设计院 实现信息系统安全管理
- Codeforces 997E Good Subsegments (线段树)
- boost::fruchterman_reingold_force_directed_layout用法的测试程序
- JAVA听力源码,英语听力练习
- python中时间模块
- 分布式事务Seata的AT模式下两阶段提交原理
- (转) Arcgis for js之WKT和GEOMETRY的相互转换
- tensorflow画损失函数的代码_使用TensorFlow编写您的第一个神经网络
- 调用阿里API创建阿里云主机
- 3种顺序排序方法。简单排序是指时间复杂度为O(n^2)的排序方法。
- 苹果支付IAP V1
- USB OTG(Host) 、 USB ADB(Device)、DWC3 Charge
- 小白有这六个Python学习网站,比那些收费几百几千的还要好用
- Java面试问题总结归纳
- 程序人生之九:2012,回首这7年
- 大学生实习就业调研报告:8个共性问题与企业CTO/CEO/HR管理者探讨
- 将PPT转化为长图(长截图)【Python方法】
- 利用python 绘制有效边界efficient frontier