假设有一个场景:每个线程代表一个跑步运动员,当运动员都准备好后,才一起出发,只要有一个人没准备好,大家都得等待。
直接上代码:
public class UseCyclicBarrier {
static class Runner implements Runnable{
private String name;
private CyclicBarrier cb; //传入CyclicBarrier,调用await方法,所有的Runner传入的是同一个CyclicBarrier
public Runner(CyclicBarrier cb,String name){
this.cb = cb;
this.name = name;
}
@Override
public void run() {
try {
Thread.sleep(1000*new Random().nextInt(5));
System.out.println(name+"准备好了");
cb.await();
} catch (InterruptedException | BrokenBarrierException e) {
e.printStackTrace();
}
System.out.println(name+"出发!");
}
}
public static void main(String[] args) {
CyclicBarrier cb = new CyclicBarrier(3);
ExecutorService pool = Executors.newFixedThreadPool(3);
pool.submit(new Runner(cb,"1号选手"));
pool.submit(new Runner(cb,"2号选手"));
pool.submit(new Runner(cb,"3号选手"));
pool.shutdown();
}
}
执行结果:可以看到,当3个线程都调用了await方法,就是三个都准备好了,才一起打印出发的语句。
1号选手准备好了
2号选手准备好了
3号选手准备好了
3号选手出发!
1号选手出发!
2号选手出发!
2、我们现在尝试一下如果将CyclicBarrier初始化的参数改为4呢。
CyclicBarrier cb = new CyclicBarrier(4);
执行结果:可以发现当三个线程都准备好了,可是还是没打印出发。因为初始化的4的意思是,只要四个线程都调用了await方法,即四个线程都准备好了,才会一起出发。
2号选手准备好了
1号选手准备好了
3号选手准备好了