使用嵌套的Parallel.For

Fil*_*erg 6 c# .net-4.0 task-parallel-library

考虑这个例子:

var x = 0;

for (var i = 0; i < 100; i++ )
{
    for (var a = i+1; a < 100; a++)
        x += 1;
}
Run Code Online (Sandbox Code Playgroud)

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

这就是我想出的

Parallel.For(0, 100, i => Parallel.For(i + 1, 100, a => { x += 1; }));
Run Code Online (Sandbox Code Playgroud)

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

Pon*_*gge 13

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

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