zoukankan      html  css  js  c++  java
  • 【C#】【Thread】Barrier任务并行

    Barrier  是一个对象,它可以在并行操作中的所有任务都达到相应的关卡之前,阻止各个任务继续执行。 如果并行操作是分阶段执行的,并且每一阶段要求各任务之间进行同步,则可以使用该对象。 ——MSDN

    复制代码
            private void BarrierTest()
            {
                Barrier bar = new Barrier(4);
                Task[] task = new Task[4];
                Action act = () =>
                {
                    MessageBox.Show("start");
                    bar.SignalAndWait();
                    MessageBox.Show("minddle");
                    bar.SignalAndWait();
                    MessageBox.Show("end");
                };
                for (int i = 0; i < task.Length; ++i)
                {
                    task[i] = new Task(act);
                    task[i].Start();
                }
            }        
    复制代码

    简单理解就是:

    设定一个量,每个线程运行到这停止,等其他所有线程都到达这个点,然后继续运行。

    上述例子可以看出:

    设定了 4 这个数量,然后4个线程同时运行,先弹出4个start,然后一个一个点掉,当最后一个点击掉之后一起弹出4个middle.....

    也就是说不会因为第一个start点掉了,马上就弹出一个middle,要等4个都点掉....

     Barrier 和 CountdownEvent非常接近类似

    http://www.cnblogs.com/mqxs/p/6237496.html

  • 相关阅读:
    python_levenshtein 的安装和使用
    接口测试困难
    pycharm修改windows的IP
    Excel读取,修改,新建
    appium混合应用的处理
    冒泡排序
    选择排序
    插入排序
    python中两种退出方式os._exit(),sys.exit()
    二分查找
  • 原文地址:https://www.cnblogs.com/cmblogs/p/9138263.html
Copyright © 2011-2022 走看看