一、概述
CyclicBarrier的中文是循环栅栏的意思,该工具类会像栅栏一样,把线程拦住(阻塞),当拦住的线程的数量达到预定设置的值之后,会将阻塞的线程全部唤醒。循环是指CyclicBarrier可以重复使用,而CountDownLatch只能使用一次
二、常用方法
CyclicBarrier(int parties) : 构造函数,指定计数器中的值
await() throws InterruptedException, BrokenBarrierException :阻塞当前线程,阻塞的线程数+1,当阻塞的线程数达到计数器中设定的值,将会唤醒。
三、案例
public class Demo {
public static void main(String[] args) {
int count = 5;
CyclicBarrier cyclicBarrier = new CyclicBarrier(count);
for (int i = 1; i <=count ; i++) {
Thread t = new Thread(()->{
//随机沉睡时间
int time = (int)(Math.random()*10+1);
try {
TimeUnit.SECONDS.sleep(time);
System.out.println(Thread.currentThread().getName()+"执行业务"+time+"秒,达到终点,等待其他线程");
cyclicBarrier.await();
System.out.println(count+"个线程全部到达终点,"+Thread.currentThread().getName()+"继续往下执行");
} catch (InterruptedException | BrokenBarrierException e) {
e.printStackTrace();
}
});
t.setName("线程"+i);
t.start();
}
System.out.println("mian线程执行完毕");
}
}
执行结果:
mian线程执行完毕
线程4执行业务1秒,达到终点,等待其他线程
线程3执行业务1秒,达到终点,等待其他线程
线程1执行业务3秒,达到终点,等待其他线程
线程2执行业务7秒,达到终点,等待其他线程
线程5执行业务10秒,达到终点,等待其他线程
5个线程全部到达终点,线程5继续往下执行
5个线程全部到达终点,线程2继续往下执行
5个线程全部到达终点,线程1继续往下执行
5个线程全部到达终点,线程3继续往下执行
5个线程全部到达终点,线程4继续往下执行