c# – 使用嵌套的Parallel.For

c# – 使用嵌套的Parallel.For,第1张

概述考虑这个例子: var x = 0;for (var i = 0; i < 100; i++ ){ for (var a = i+1; a < 100; a++) x += 1;} 打印x时,我们总是得到4950.如果我要将其并行化怎么办? 这就是我想出的 Parallel.For(0, 100, i => Parallel.For(i + 1, 100, a => 考虑这个例子:
var x = 0;for (var i = 0; i < 100; i++ ){    for (var a = i+1; a < 100; a++)        x += 1;}

打印x时,我们总是得到4950.如果我要将其并行化怎么办?

这就是我想出的

Parallel.For(0,100,i => Parallel.For(i + 1,a => { x += 1; }));

但是,每次运行时都不会打印4950.为什么?

解决方法 Parallel Extensions以近乎迫切的语法帮助您创建任务,分配,运行和集合.它不做的是照顾各种线程安全( pitfalls之一).您正在尝试使并行线程同时更新单个共享变量.要正确地做这样的事情,你必须引入例如锁定.

我不确定你要做什么.我假设您的代码只是一个占位符或实验.并行化仅适用于您可以隔离不同的工作;不是当你经常不得不与共享数据会合时.

总结

以上是内存溢出为你收集整理的c# – 使用嵌套的Parallel.For全部内容,希望文章能够帮你解决c# – 使用嵌套的Parallel.For所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1236861.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-06
下一篇 2022-06-06

发表评论

登录后才能评论

评论列表(0条)

保存