C# 并行编程 之 Barrier的使用 - 通过屏障同步并发任务

基本信息

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);
         
  • 3
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值