2. 通过 Barrier 类实现
  除了通过等待句柄可以实现题目要求外,同样可以通过 Wait 和 Pulse 来实现。如果是FrameWork 4.0或更高的版本,可以通过 Barrier 类(它是建立在 Wait / Pulse 和自旋锁基础上的)更简单的实现这个题目。
class Program
{
private static Barrier _barrier;
private static void Main(string[] args)
{
var fileNames = new List<string> { "A", "B", "C", "D" };
// 创建或清空文件
fileNames.ForEach(name =>
{
if (!File.Exists(name))
File.Create(name).Close();
else
{
using (var sw = new StreamWriter(name))
sw.Write("");
}
});
// 在_barrier上调用SignalAndWait的线程会被阻塞直到这个方法被调用4次
_barrier = new Barrier(4);
_sws = fileNames.Select(File.AppendText).ToList();
// 创建并启4个线程执行任务
var threads = new List<Thread> {
new Thread(() => Work(1)), new Thread(() => Work(2)), new Thread(() => Work(3)), new Thread(() => Work(4))
};
threads.ForEach(t => t.Start());
// 等待线程结束并关闭 StreamWrite
threads.ForEach(t => t.Join());
Console.WriteLine("任务完成!");
_sws.ForEach(sw => sw.Close());
}
static void Work(int threadIndex)
{
var next = threadIndex - 1;
for (int i = 0; i < 100; i++)
{
var sw = _sws[next];
lock (sw)
{
sw.Write(threadIndex);
}
_barrier.SignalAndWait();
next = (next - 1) < 0 ? 3 : next - 1;
}
}
}
  使用了一个 Barrier 类来替代4个等待句柄,线程调用 SignalAndWait 后会阻塞,直到这个方法被调用4次。在这个例子中意味着4个线程总是在同步进行着打印,下图可以很好的解释 Barrier 类: