等待多个线程到达之后执行,可以循环使用
它允许一组线程互相等待,直到到达某个公共屏障点 (common barrier point)。在涉及一组固定大小的线程的程序中,这些线程必须不时地互相等待,此时 CyclicBarrier 很有用。因为该 barrier 在释放等待线程后可以重用,所以称它为循环 的 barrier。
通俗点讲就是:让一组线程到达一个屏障时被阻塞,直到最后一个线程到达屏障时,屏障才会开门,所有被屏障拦截的线程才会继续干活。
private static CyclicBarrier barrier;
static class CyclicTest extends Thread{
@Override
public void run(){
System.out.println(Thread.currentThread().getName() + "已经到了");
try {
barrier.await();
} catch (InterruptedException e) {
e.printStackTrace();
} catch (BrokenBarrierException e) {
e.printStackTrace();
}
}
}
public static void main(String[] args) {
barrier = new CyclicBarrier(5,new Runnable() {
@Override
public void run() {
System.out.println("我们准备出发吧");
}
});
for(int i=0;i<20; i++){
new CyclicTest().start();
}
Thread-0已经到了
Thread-2已经到了
Thread-1已经到了
Thread-3已经到了
Thread-5已经到了
我们准备出发吧
Thread-4已经到了
Thread-8已经到了
Thread-9已经到了
Thread-7已经到了
Thread-11已经到了
我们准备出发吧
Thread-6已经到了
Thread-10已经到了
Thread-12已经到了
Thread-13已经到了
Thread-14已经到了
我们准备出发吧
Thread-19已经到了
Thread-16已经到了
Thread-15已经到了
Thread-17已经到了
Thread-18已经到了
我们准备出发吧