CyclicBarrier 的字面意思是可循环使用(Cyclic)的屏障(Barrier)。它要做的事情是,让一组线程到达一个屏障(也可以叫同步点)时被阻塞,直到最后一个线程到达屏障时,屏障才会开门,所有被屏障拦截的线程才会继续干活。
构造方法:
CyclicBarrier(int parties)
创建一个新的
CyclicBarrier ,当给定数量的线程(线程)等待它时,它将跳闸,并且当屏障跳闸时不执行预定义的动作。
|
CyclicBarrier(int parties, Runnable barrierAction)
创建一个新的
CyclicBarrier ,当给定数量的线程(线程)等待时,它将跳闸,当屏障跳闸时执行给定的屏障动作,由最后一个进入屏障的线程执行。
|
CyclicBarrier还提供一个更高级的构造函数CyclicBarrier(int parties, Runnable barrierAction),用于在线程到达屏障时,优先执行barrierAction,方便处理更复杂的业务场景。
实例方法:
int | await()
等待所有
parties已经在这个障碍上调用了
await 。
|
int | await(long timeout, TimeUnit unit)
等待所有
parties已经在此屏障上调用
await ,或指定的等待时间过去。
|
int | getNumberWaiting()
返回目前正在等待障碍的各方的数量。
|
int | getParties()
返回旅行这个障碍所需的聚会数量。
|
boolean | isBroken()
查询这个障碍是否处于破碎状态。
|
void | reset()
将屏障重置为初始状态。
|
isBroken()方法:判断是否出现异常,返回true表示一个或多个参与方因施工或最后一次重置而导致中断或超时,或由于异常而导致屏障动作失败.
CyclicBarrier的应用场景
CyclicBarrier可以用于多线程计算数据,最后合并计算结果的应用场景。比如我们用一个Excel保存了用户所有银行流水,每个Sheet保存一个帐户近一年的每笔银行流水,现在需要统计用户的日均银行流水,先用多线程处理每个sheet里的银行流水,都执行完之后,得到每个sheet的日均银行流水,最后,再用barrierAction用这些线程的计算结果,计算出整个Excel的日均银行流水。
相关实例:赛跑时,等待所有人都准备好时,才起跑:
输出结果:
3号选手 准备好了... 2号选手 准备好了... 1号选手 准备好了... 1号选手 起跑! 2号选手 起跑! 3号选手 起跑!
转载地址:http://www.itzhai.com/the-introduction-and-use-of-cyclicbarrier.html