概述
CyclicBarrier循环栅栏(循环屏障)是一种同步帮助,当多个线程一起执行任务是,一个线程没有完成任务,其他线程都必须进入等待状态,等待这个线程完成任务后,才能再执行其他任务。强调相互等待,一个线程不完成,其他线程全部等待。
例如:一个公司去团建,需要大家全部集合完毕后,才能出发,有一个人员不到,全员都得等待。
public class CyclicBarrierDemo {
public static void main(String[] args) {
CyclicBarrier cyclicBarrier=new CyclicBarrier(10,()->{
System.out.println("全员到齐,出发");
});
for (int i = 1; i <=10; i++) {
new Thread(()->{
try {
System.out.println(Thread.currentThread().getName()+"到,");
//类似于点名,到一个人调用这个方法进行加一操作,然后等十个人都到齐后,放开屏障,再进行下一步
cyclicBarrier.await();
} catch (InterruptedException e) {
e.printStackTrace();
} catch (BrokenBarrierException e) {
e.printStackTrace();
}
},i+"").start();
}
}
}
原理
CyclicBarrier 的字面意思是可循环(Cyclic)使用的屏障(Barrier)。它要做的事情是,让一组线程到达一个屏障(也可以叫同步点)时被阻塞,直到最后一个线程到达屏障时,屏障才会开门,所有被屏障拦截的线程才会继续干活。线程进入屏障通过CyclicBarrier的await()方法。
运行结果
1到,
2到,
3到,
4到,
5到,
6到,
7到,
8到,
9到,
10到,
全员到齐,出发