package player.kent.chen.learn.barrier; import java.util.concurrent.BrokenBarrierException; import java.util.concurrent.CyclicBarrier; public class HelloBarrier { /** * 大家都到齐后,再一起开火 */ private static final class FireTogether implements Runnable { private CyclicBarrier barrier; public FireTogether(CyclicBarrier barrier) { super(); this.barrier = barrier; } public void run() { try { barrier.await(); //等别的线程到达集合点 System.out.println(Thread.currentThread().getName() + ": 哥开火了!"); } catch (InterruptedException e) { Thread.currentThread().interrupt(); } catch (BrokenBarrierException e) { System.out.println(Thread.currentThread().getName() + ": 有人放鸽子。我不开火"); } } } public static void main(String[] args) throws InterruptedException { int numOfThreads = 5; CyclicBarrier barrier = new CyclicBarrier(numOfThreads, new Runnable() { public void run() { System.out.println("大家都到齐了"); //到齐时打印一条信息 } }); Thread[] threads = new Thread[numOfThreads]; for (int i = 0; i < threads.length; i++) { threads[i] = new Thread(new FireTogether(barrier)); threads[i].setName("fire-thread-" + i); } for (Thread thread : threads) { thread.start(); System.out.println(thread.getName() + " 已经动身了 "); Thread.sleep(1000l); //动身时间间隔一秒 } } }
输出:
引用
fire-thread-0 已经动身了
fire-thread-1 已经动身了
fire-thread-2 已经动身了
fire-thread-3 已经动身了
fire-thread-4 已经动身了
大家都到齐了
fire-thread-4: 哥开火了!
fire-thread-0: 哥开火了!
fire-thread-2: 哥开火了!
fire-thread-1: 哥开火了!
fire-thread-3: 哥开火了!
如果 Thread[] threads = new Thread[numOfThreads] 改成 Thread[] threads = new Thread[2 * numOfThreads] ,也就是说barrier仍然等5个线程就发,但现在共有10个线程,执行结果是:
引用
fire-thread-0 已经动身了
fire-thread-1 已经动身了
fire-thread-2 已经动身了
fire-thread-3 已经动身了
fire-thread-4 已经动身了
大家都到齐了
fire-thread-4: 哥开火了!
fire-thread-0: 哥开火了!
fire-thread-2: 哥开火了!
fire-thread-1: 哥开火了!
fire-thread-3: 哥开火了!
fire-thread-5 已经动身了
fire-thread-6 已经动身了
fire-thread-7 已经动身了
fire-thread-8 已经动身了
fire-thread-9 已经动身了
大家都到齐了
fire-thread-9: 哥开火了!
fire-thread-5: 哥开火了!
fire-thread-6: 哥开火了!
fire-thread-7: 哥开火了!
fire-thread-8: 哥开火了!
可见barrier一共发了两批,也就是说barrier得到了重用,这就是’CyclicBarrier’类名中有"cyclic"的原因。