1

这段代码的输出每次都不同。是否可以从 0 到 21 顺序输出 i(迭代计数)?

  static void Main(string[] args)
    {

        int N = 1000;
            Parallel.For(0, N, (i, loop) =>
            {
                Console.WriteLine(i);
                if (i == 21)
                {
                    loop.Break();
                }
            });
            Console.ReadLine();
    }
4

2 回答 2

6

当使用 Parallel.For 方法时,不能保证特定的执行顺序。优点是循环在具有可用内核的计算机上完成得更快,因为这些步骤通常同时并行进行。您仍然可以保证所有循环的迭代都将在循环完成时运行,但不能保证它们运行的​​顺序。如果要运行顺序循环,则应使用for.

于 2014-07-10T03:15:27.917 回答
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
于 2014-07-10T03:27:55.920 回答