CyclicBarrier是循环(Cyclic)+Barrier(屏障),只有当线程达到一定数量时,才会继续执行。类似于组团旅游,打麻将三缺一,有的线程达到比较早,会一起等待还没有到达的线程。
CountDownLatch是主线程await阻塞,类似于一个“倒计时器”,工作线程每完成一个子任务都会调用countdown方法(state-1),直到state减到0,主线程才会继续。
它们都是java.util.concurrent包下的线程同步类,用于一个任务的分发处理。
不同点:
- 最大的差别在于,CyclicBarrier可以重复使用,而CountDownLatch是一次性的。(环保部门说:不提倡使用一次性快餐用具)
- 当某个工作线程发生中断时,CyclicBarrier会把所有在等待的线程唤醒,该屏障会被打破,调用reset方法后还可以继续使用;而CountDownLatch的某个工作线程中断后,所有线程会一直等待。
- CyclicBarrier的工作线程完成任务后,在屏障点到达前,会一直等待,也就是会存在多个线程同时等待的情况;而CountDownLatch的主线程会await阻塞在那里,工作线程完成任务后可以一般都会终止。