您的位置:首页 > 运维架构

Parallel Stop与Break的理解

2015-08-04 15:00 323 查看
普通for循环、foreach循环中有break/continue用于流程控制,在Parallel中也有用于流程控制的方法,即ParallelLoopState类的Stop/Break方法。

一、Stop方法用于退出Paraller循环

看下面的代码:

var ltNum = new List<int>();
for (int i = 1; i <= 10; i++)
{
ltNum.Add(i);
}
Parallel.For(0, ltNum.Count, (i, loopState) =>
{
if (i > 5)
{
loopState.Stop();
return;
}
Console.WriteLine("下标:{0},值:{1}", i, ltNum[i]);
});


其中loopState是ParallelLoopState类实例,用于并行循环流程控制。

注意第10行:loopState.Stop(); 表示立刻退循环,不论后面要执行的循环是否满足i>5这个条件。

二、Break用于根据条件过滤循环

假如将上面第10行代码改为:loopState.Break(); 则表示后面满足i>5的循环不再执行,但其它的循环体还是要执行的。

注意:不论是Break还是Stop方法,后面的return语句是必须的,否则当前循环体第13行的语句还是会被执行。

三、总结

下面用一个表格比较Parallel中的Stop/Break方法与普通循环中的continue/break语句的类比。

ParrallelLoopState实例方法Stop()Break()
作用退出循环,后面的循环体均不执行满足相应条件的循环体不执行
相当于普通循环的语句break;continue
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: