Я никогда не использовал Parallel.ForEach
, но я играл с ним и нашел это явление.Параллельный ForEach Предоставление разных результатов в разных оккасиях
Я бег параллельного цикла (код найти на MSDN https://msdn.microsoft.com/en-us/library/dd997393(v=vs.110).aspx сделал редактировать его с subtotal *=2
, чтобы попытаться понять, что он делает) с перечислимым диапазоном, во-первыми (0,1)
, а затем (0,1,2)
потом запустить второй раз, но после сна нити в течение 200 миллисекунд, а затем результат отличается
если Thread.sleep(200)
не закомментирован это результаты
result 1 = 2
result 2 = 6
result 3 = 4
если Thread.sleep(200)
закомментирован это результаты
result 1 = 2
result 2 = 6
result 3 = 6
Вот код
Stopwatch timer = new Stopwatch();
int[] nums = Enumerable.Range(0, 1).ToArray();
long total = 0;
for (int i = 0; i < 2; i++)
{
timer.Restart();
total = 0;
if (i == 0) nums = Enumerable.Range(0, 1).ToArray();
if (i == 1) nums = Enumerable.Range(0, 2).ToArray();
Parallel.ForEach<int, long>(nums,() => 0,(j, loop, subtotal) =>
{
subtotal += 1;
subtotal *= 2;
return subtotal;
},(finalResult) => Interlocked.Add(ref total, finalResult));
Console.WriteLine("The total from Parallel.ForEach is {0:N0} and took {1}", total, timer.Elapsed);
timer.Stop();
//Thread.Sleep(200);
}
timer.Restart();
nums = Enumerable.Range(0, 2).ToArray();
total = 0;
Parallel.ForEach<int, long>(nums,() => 0, (j, loop, subtotal) =>
{
subtotal += 1;
subtotal *= 2;
return subtotal;
},(finalResult) => Interlocked.Add(ref total, finalResult));
Console.WriteLine("The total from Parallel.ForEach is {0:N0} and took {1}", total, timer.Elapsed);
timer.Stop();
я понял, это надо делать с нитями, работающих друг над другом, но это, кажется, как ошибка
Примечание Я сделал взглянуть на Simulation gives different result with normal for loop Vs Parallel For
Почему это происходит?
@ JánЯabčan Можете ли вы подать se разработать. Я не понимаю, что делает этот код, когда он умножает 2 и почему? – Neil
Я даже не понимаю, как вы получаете свои результаты ... – sam
@sam измените ваш thread.sleep на 1000 и посмотрите, получите ли вы его – Neil