CyclicBarrier(循环的栅栏)
-
类说明:
一个同步辅助类,它允许一组线程互相等待,直到到达某个公共屏障点 (common barrier point)。在涉及一组固定大小的线程的程序中,这些线程必须不时地互相等待,此时 CyclicBarrier 很有用。因为该 barrier 在释放等待线程后可以重用,所以称它为循环 的 barrier。 -
使用场景:
需要所有的子任务都完成时,才执行主任务,这个时候就可以选择使用CyclicBarrier。 -
常用方法:
await:在所有参与者都已经在此 barrier 上调用 await方法之前,将一直等待。如果当前线程不是将到达的最后一个线程,出于调度目的,将禁用它,且在发生以下情况之一前,该线程将一直处于休眠状态 -
getNumberWaiting() 获取阻塞线程的数量
public class Demo { public static void main(String[] args) { CyclicBarrier cb = new CyclicBarrier(5, new Runnable() {//第二个参数的任务会优先于await()后的执行 @Override public void run() { System.out.println("到齐之后拍照留念"); System.out.println("人员全部到齐开始吃饭"); try { Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } } }); ExecutorService threadPool = Executors.newCachedThreadPool(); for (int i = 0; i <5 ; i++) { final int user = i+1; Runnable runnable = new Runnable() { @Override public void run() { try { Thread.sleep((long)(Math.random()*10000)); System.out.println(user+"到达聚餐现场,当前已有"+(cb.getNumberWaiting()+1)+"人到达现场"); cb.await(); Thread.sleep((long)(Math.random()*10000)); System.out.println(user+"用户吃完饭,准备回家"); } catch (Exception e) { e.printStackTrace(); } } }; threadPool.execute(runnable); } threadPool.shutdown(); } }