此代码的输出每次都不同。是否可以将i(迭代计数)的顺序输出从0到21?
static void Main(string[] args)
{
int N = 1000;
Parallel.For(0, N, (i, loop) =>
{
Console.WriteLine(i);
if (i == 21)
{
loop.Break();
}
});
Console.ReadLine();
}
答案 0 :(得分:6)
当使用Parallel.For方法时,不保证特定的执行顺序。优点是循环在具有可用核心的计算机上完成得更快,因为这些步骤通常同时并行进行。您仍然可以保证所有循环的迭代将在循环结束时运行,但不会保证它们的顺序。如果要运行顺序循环,则应使用for
。
答案 1 :(得分:4)
改为使用foreach循环:
foreach (var VARIABLE in (Enumerable.Range(0, 10).AsParallel().AsOrdered()))
{
Console.WriteLine(VARIABLE);
}
带索引的示例
foreach (var obj in Enumerable.Range(0, 10)
.Select((s, i) => new {index = i, value = s})
.AsParallel()
.Select(obj => new {obj.index, value = obj.value*obj.value, thread=Thread.CurrentThread.ManagedThreadId})
.OrderBy(o => o.index))
{
Console.WriteLine("{0}:{1} on {2}", obj.index, obj.value, obj.thread);
}
Core i7的结果。
0:0 on 1
1:1 on 3
2:4 on 5
3:9 on 1
4:16 on 1
5:25 on 1
6:36 on 1
7:49 on 1
8:64 on 1
9:81 on 1