zoukankan      html  css  js  c++  java
  • 深入理解JUC:第五章:CyclicBarrier循环栅栏

    理论:

    它的作用就是会让所有线程都等待完成后才会继续下一步行动。

    举个例子,就像生活中我们会约朋友们到某个餐厅一起吃饭,有些朋友可能会早到,有些朋友可能会晚到,但是这个餐厅规定必须等到所有人到齐之后才会让我们进去。这里的朋友们就是各个线程,餐厅就是 CyclicBarrier。

    未使用循环栅栏的代码:

    public class Demo {
    
        public static void main(String[] args) throws Exception{
            for (int i = 1; i <= 6; i++) {
                final int tempInt = i;
                new Thread(()->{
                    System.out.println(tempInt+"朋友到了");
                },String.valueOf(i)).start();
            }
            System.out.println("朋友全部到了,才开始吃饭");
        }
    }

    控制台:

    使用CyclicBarrier的代码:

    import java.util.concurrent.BrokenBarrierException;
    import java.util.concurrent.CyclicBarrier;
    
    
    public class Demo {
    
        public static void main(String[] args) throws Exception{
            CyclicBarrier cyclicBarrier = new CyclicBarrier(6,()->{System.out.println("朋友全部到了,才开始吃饭");});
            for (int i = 1; i <= 6; i++) {
                final int tempInt = i;
                new Thread(()->{
                    System.out.println(tempInt+"朋友到了");
                    try {
                        cyclicBarrier.await();
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    } catch (BrokenBarrierException e) {
                        e.printStackTrace();
                    }
                },String.valueOf(i)).start();
    
            }
        }
    }
    

    控制台:

  • 相关阅读:
    求最大的矩形(悬线法)
    限制不互素对的排列(构造)
    括号(构造)
    G. 4.奶牛(二进制枚举)
    新飞行棋(上楼梯)
    小天狼星的访问
    欧拉筛线性筛法,约数和和约数个数
    Find The Multiple
    How Many O's? UVA
    GCD LCM UVA
  • 原文地址:https://www.cnblogs.com/javawxid/p/12811906.html
Copyright © 2011-2022 走看看