基本信息
Barrier 是 .Net 提供的一直并发的机制,它允许多个任务同步他们不同阶段的并发工作。
这里的关键点是【多个任务】和【不同阶段】。
假设有4个相同的任务(Task),每个任务都有4个阶段(Phase),当他们并发工作时,只有当所有任务的相同步骤都完成时,所有任务才可以开始下一个步骤。
如图所示:
这里的 Barrier 就是 .NetFramework 提供的一种机制。它像一个篱笆(屏障),把所有任务的阶段隔离开来,当前阶段不完成,不会开始下一个阶段。
代码示例:
using System;
using System.Threading;
using System.Threading.Tasks;
namespace Sample5_1_barrier
{
class Program
{
private static void Phase0Doing(int TaskID)
{
Console.WriteLine("Task : #{0} ===== Phase 0", TaskID);
}
private static void Phase1Doing(int TaskID)
{
Console.WriteLine("Task : #{0} ***** Phase 1", TaskID);
}
private static void Phase2Doing(int TaskID)
{
Console.WriteLine("Task : #{0} ^^^^^ Phase 2", TaskID);
}
private static void Phase3Doing(int TaskID)
{
Console.WriteLine("Task : #{0} $$$$$ Phase 3", TaskID);
}
private static int _TaskNum = 4;
private static Task[] _Tasks;
private static Barrier _Barrier;
static void Main(string[] args)
{
_Tasks = new Task[_TaskNum];
_Barrier = new Barrier(_TaskNum, (barrier) =>
{
Console.WriteLine("-------------------------- Current Phase:{0} --------------------------",
_Barrier.CurrentPhaseNumber);
});
for (int i = 0; i < _TaskNum; i++)
{
_Tasks[i] = Task.Factory.StartNew((num) =>
{
var taskid = (int)num;
Phase0Doing(taskid);
_Barrier.SignalAndWait();
Phase1Doing(taskid);