Parallel.ForEach 方法
2011-04-09 11:26
316 查看
Parallel.ForEach 方法并行的执行ForEach,它的重载方法也很多。
http://msdn.microsoft.com/zh-cn/library/system.threading.tasks.parallel.foreach.aspx。
最简单的是下面这个
ForEach<TSource>(IEnumerable<TSource>, Action<TSource>)
一个枚举器参数和一个Action委托。
static void Main(string[] args)
{
Parallel.ForEach("Hello, world", (c) =>
{
Console.WriteLine(c.ToString());
});
}
Because the loop body in a parallel For or ForEach is a delegate, you can’t exit
the loop early with a break statement. Instead, you must call Break or Stop on a
ParallelLoopState object:
由于并行的For和Foreach方法的循环体是一个委托,所以不能通过break退出循环体,你只能使用ParallelLoopState 对象的Break或者Stop方法来退出一个并行循环
For和Foreach所有的所有重载函数都接受一个Action<TSource,ParallelLoopState>委托,这里可以在循环体里使用ParallelLoopState。
ParallelLoopState.Break()方法,:在完成当前的这轮工作之后,不再执行后继的工作,但在当前这轮工作开始之前“已经在执行”的工作,则必须完成。
ParallelLoopState.Stop方法时,不但不会再创建新的线程执行并行循环,而且当前“已经在执行”的工作也应该被中止
Stop 和 Break 的方法的区别非常微妙,需要仔细体会,可以简单地用两句话来表达:
n ParallelLoopState.Stop 方法中止“当前”及“以后”的工作任务,会导致 ParallelLoopState 对象的 IsStop 属性值等于 true 。
n ParallelLoopState.Break() 方法仅中止“以后”的工作任务,会导致 ParallelLoopState 对象的 LowestBreakIteration 属性值等于 true 。
本文出自 “一只博客” 博客,请务必保留此出处http://cnn237111.blog.51cto.com/2359144/538910
http://msdn.microsoft.com/zh-cn/library/system.threading.tasks.parallel.foreach.aspx。
最简单的是下面这个
ForEach<TSource>(IEnumerable<TSource>, Action<TSource>)
一个枚举器参数和一个Action委托。
static void Main(string[] args)
{
Parallel.ForEach("Hello, world", (c) =>
{
Console.WriteLine(c.ToString());
});
}
Because the loop body in a parallel For or ForEach is a delegate, you can’t exit
the loop early with a break statement. Instead, you must call Break or Stop on a
ParallelLoopState object:
由于并行的For和Foreach方法的循环体是一个委托,所以不能通过break退出循环体,你只能使用ParallelLoopState 对象的Break或者Stop方法来退出一个并行循环
For和Foreach所有的所有重载函数都接受一个Action<TSource,ParallelLoopState>委托,这里可以在循环体里使用ParallelLoopState。
ParallelLoopState.Break()方法,:在完成当前的这轮工作之后,不再执行后继的工作,但在当前这轮工作开始之前“已经在执行”的工作,则必须完成。
ParallelLoopState.Stop方法时,不但不会再创建新的线程执行并行循环,而且当前“已经在执行”的工作也应该被中止
Stop 和 Break 的方法的区别非常微妙,需要仔细体会,可以简单地用两句话来表达:
n ParallelLoopState.Stop 方法中止“当前”及“以后”的工作任务,会导致 ParallelLoopState 对象的 IsStop 属性值等于 true 。
n ParallelLoopState.Break() 方法仅中止“以后”的工作任务,会导致 ParallelLoopState 对象的 LowestBreakIteration 属性值等于 true 。
本文出自 “一只博客” 博客,请务必保留此出处http://cnn237111.blog.51cto.com/2359144/538910
相关文章推荐
- Parallel.Foreach的并发问题解决方法-比如爬虫WebClient
- 看看Parallel中高度封装的三个方法,Invoke,For和ForEach
- 看看Parallel中高度封装的三个方法,Invoke,For和ForEach
- C#多线程 为多核处理器而生的多线程方法Parallel.For和Parallel.ForEach
- .NET4中多线程并行方法Parallel.ForEach
- Javascript数组Array的forEach方法
- PHP 数组遍历方法大全(foreach,list,each)
- 使用Lambda表达式遍历集合(forEach方法)
- List的ForEach方法
- Java 8 lambda stream forEach parallel 等循环与Java 7 for each 循环耗时测试
- .net concurrency(parallel) -data concurrency foreach
- c++中foreach的一种实现方法
- C#中foreach出现“集合已修改 可能无法执行枚举操作”的解决方法
- 简单标签实现foreach代码和jar打包的两种方法
- JavaScript里的循环方法:forEach,for-in,for-of
- mybatis中foreach使用方法
- 一张图看懂JavaScript中数组的迭代方法:forEach、map、filter、reduce、every、some
- 开发记录:使用 array_column把id变作键名的方法,比foreach方便了
- <c:foreach>同时遍历两个List的方法
- C# 列表类Find()方法的Predicate match参数 和 ForEach()方法的Action action参数实现