如何一文了解CyclicBarrier(可重复使用的栅栏阻塞-JUC)

简介

CyclicBarrier 是可循环使用的栅栏。默认的构造方法是CyclicBarrier(int parties),其参数表示屏障将同时拦截的线程数量,每个线程使用await()方法告诉CyclicBarrier我已经到达了屏障,然后当前线程被阻塞。直到parties个参与线程都调用了await方法,那么栅栏将打开,此时所有被栅栏拦截的线程都将继续往下执行,而栅栏将被重置以便下次使用。

模拟6人员会议,先到的人员等待,所有人员到齐时,参会人员开始讨论

import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;

public class CyclicBarrierDemo {
    public static void main(String[] args) {
        // 人员数为6,栅栏需要拦截5位提前到达的人员。
        int memberCount = 6;
        CyclicBarrier cyclicBarrier = new CyclicBarrier(memberCount);
        // 开启6个人员线程
        for(int i = 1; i <= 6; i++) {
            new Thread(() -> {
                try {
                    // 先到达的人员开始等待
                    System.out.println(Thread.currentThread().getName() + " 号人员到达会议室");
                    cyclicBarrier.await();
                    // 人到齐时,该人员才参与讨论
                    System.out.println(Thread.currentThread().getName() + " 号人员参与讨论");
                } catch (InterruptedException e) {
                    e.printStackTrace();
                } catch (BrokenBarrierException e) {
                    e.printStackTrace();
                }
            }, String.valueOf(i)).start();
        }
    }
}

运行结果和分析如下

如何一文了解CyclicBarrier(可重复使用的栅栏阻塞-JUC)_第1张图片

此时先到达的线程被栅栏所拦截,没有直接立刻进行讨论。当6位人员线程都被阻塞时,每个人员线程会接着从阻塞位置开始往下执行,即才开始讨论

你可能感兴趣的:(juc并发编程)