大家好,又见面了,我是你们的朋友全栈君。
在Foreach的时候需要多加一个ParallelLoopState
var parallelOption = new ParallelOptions() { MaxDegreeOfParallelism = 6 };
Parallel.ForEach(As, parallelOption, (A,ParallelLoopState) =>
{
if(needContinue){
ParallelLoopState.Break();//告诉CPU之后的迭代不需要执行,如0-1000的判断,从100开始break,则100之前的任然执行,从101开始到1000都不需要执行了
return;//不加return,可能会发生该进程资源未释放。
}
}
Parallel.ForEach(As, parallelOption, (A, ParallelLoopState) =>
{
if(needBreak){
ParallelLoopState.Stop();//告诉CPU放弃整个迭代
return;//不加return,可能会发生该进程资源未释放。
}
如果需要像For的Continue一样,则直接使用Return
}
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/161818.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...