Parallel.ForEach 方法

 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 


 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值