Parallel.For不同步输出

时间:2013-12-03 12:40:25

标签: c# task-parallel-library

我对C#4.0中的并行编程类有点新意;正在尝试一个简单的for循环,我应该通过常规for循环以顺序方式打印从0到99的长,但是使用Parallel.For,我随机混乱的顺序会得到不存在的输出。

代码:

using System.Threading.Tasks;

namespace ConsoleApplication1
{
    class Program
    {
        static void Main(string[] args)
        {

            Parallel.For(0, 100, i =>
            {
                //object sync = new object(); 
                //lock (sync)
                {
                    Console.WriteLine("Writing" + i);
                }
            });
            Console.Read();
        }
    }
}

控制台上的一个输出:

Writing0
Writing1
Writing2
Writing3
Writing4
Writing5
Writing6
Writing7
Writing8
Writing9
Writing10
Writing11
Writing12
Writing13
Writing14
Writing15
Writing16
Writing17
Writing18
Writing19
Writing20
Writing21
Writing22
Writing23
Writing24
Writing25
Writing26
Writing27
Writing28
Writing29
Writing30
Writing31
Writing32
Writing33
Writing34
Writing35
Writing36
Writing37
Writing38
Writing39
Writing40
Writing41
Writing42
Writing43
Writing44
Writing45
Writing46
Writing47
Writing48
Writing49
Writing50
Writing66
Writing67
Writing68
Writing70
Writing71
Writing72
Writing73
Writing74
Writing75
Writing76
Writing77
Writing78
Writing69
Writing82
Writing83
Writing84
Writing85
Writing86
Writing87
Writing88
Writing89
Writing90
Writing51
Writing52
Writing53
Writing54
Writing55
Writing91
Writing92
Writing93
Writing94
Writing95
Writing56
Writing57
Writing79
Writing80
Writing81
Writing58
Writing59
Writing96
Writing97
Writing98
Writing99
Writing60
Writing61
Writing62
Writing63
Writing64
Writing65

提前致谢,无论你们给我什么帮助。

2 个答案:

答案 0 :(得分:5)

那就是并行计算。任务排队,每个可用的处理器都有一个。如果完成,将向其发出下一个排队任务。没有任何关于将任务交付给处理单元的顺序的保证,也没有保证接下来要完成的任何保证,因此可顺序代码与顺序代码+关键字parallel不同。需要开发算法以便能够并行运行。在您的简单示例中,编写了从1到100的所有数字,但并行循环不会按照您期望的自然顺序编写它们。

答案 1 :(得分:0)

这是可以预料的,你在那里的工作方式是使用当前线程以及从线程池中提取的许多其他线程来划分工作。

如果你想在不同的线程上做同样的事情,但是让你的同步写,那么你可以尝试:

namespace ConsoleApplication1
{
    class Program
    {
        static void Main(string[] args)
        {
            var t = Task.Factory.StartNew(() => { 
                for(var i = 0;i<100;i++)
                {
                    //object sync = new object(); 
                    //lock (sync)
                    {
                        Console.WriteLine("Writing" + i);
                    }
                }
            });
            Console.Read();
        }
    }
}