CyclicBarrier:让一组线程到达一个屏障(也可以叫同步点)时被阻塞,直到最后一个线程到达屏障时,屏障才会开门,所有被屏障拦截的线程才会继续干活,它的构造方法传的是线程数(一组线程的数量)
public class CyclicBarrierTest {
static CyclicBarrier cb = new CyclicBarrier(2);
public static void main(String[] args) {
new Thread(){
@Override
public void run() {
try {
System.out.println("线程执行阻塞前....");
cb.await();
System.out.println("线程执行放行后....");
} catch (InterruptedException | BrokenBarrierException e) {
e.printStackTrace();
}
}
}.start();
try {
System.out.println("main阻塞前....");
cb.await();
System.out.println("main执行后....");
} catch (InterruptedException e) {
e.printStackTrace();
} catch (BrokenBarrierException e) {
e.printStackTrace();
}
}
}
接过为:
线程执行阻塞前....
main阻塞前....
main执行后....
线程执行放行后....
如果构造传了比线程实际数量多的话,那么线程就会直接阻塞在那,不会往下执行