Parallel.For跳过元素

时间:2016-09-12 13:56:01

标签: c# multithreading

在下面的代码中,似乎只有数组的每个其他元素都被填充。为什么呢?

Random rand = new Random();
int byteLength = 10000000;
var result = new byte[10][];
Parallel.For(0, 10, (i) =>
{
    int length = rand.Next(byteLength);
    var tempResult = new byte[length];
    Thread.Sleep(100);
    rand.NextBytes(tempResult);
    result[i] = tempResult;
});

与此(非并行)代码形成对比,该代码确实填充了每个元素:

rand = new Random();
var result2 = new byte[10][];
for (int i = 0; i < 10; i++)
{
    int length = rand.Next(byteLength);
    var tempResult = new byte[length];
    Thread.Sleep(100);
    rand.NextBytes(tempResult);
    result2[i] = tempResult;
}

与MSDN文档中的the examples相比,我怀疑这是因为resultParallel.For委托之外 - 因此,线程在访问result时遇到问题。但作为多线程的新手,我不确定是这种情况。

1 个答案:

答案 0 :(得分:1)

虽然Random不是线程安全的(正如其他海报对你的问题所评论)但仍然存在一个问题,即为什么你会看到无人居住的数据,因为迭代变量i不依赖于Randoms返回的值。在这种情况下,我相信Random以unthreadsafe方式调用时返回零,导致您得出结论数据未填充,但您只有一个空数组。这可以通过最初分配非空数组并查看您的例程是否将其更改为零长度来测试。我认为这是“为什么?”的完整答案。