加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 使用嵌套的Parallel.For

发布时间:2020-12-15 17:45:21 所属栏目:百科 来源:网络整理
导读:考虑这个例子: 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; })); 但是,每次运行时都
考虑这个例子:
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之一).您正在尝试使并行线程同时更新单个共享变量.要正确地做这样的事情,你必须引入例如锁定.

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读