- CyclicBarrier
A synchronization aid that allows a set of threads to all wait for each other to reach a common barrier point. CyclicBarriers are useful in programs involving a fixed sized party of threads that must occasionally wait for each other. The barrier is called cyclic because it can be re-used after the waiting threads are released.
循环障碍
一种同步辅助,它允许一组线程都等待彼此到达一个共同的障碍点。cyclicbarrier在涉及固定大小的线程的程序中非常有用,这些线程偶尔必须相互等待。这个屏障被称为循环屏障,因为在等待的线程被释放后,它可以被重用。
- CountDownLatch
A synchronization aid that allows one or more threads to wait until a set of operations being performed in other threads completes.
倒数门闩
一种同步辅助,允许一个或多个线程等待一组正在其他线程中执行的操作完成。
- CountDownLatch与CyclicBarrier区别
CountDownLatch | CyclicBarrier |
---|---|
不支持重用 | 支持重用 |
用于某个线程A等待若干个其他线程执行完任务之后,它才执行。 | 用于一组线程互相等待至某个状态,然后这一组线程再同时执行。 |
是计数器,线程完成一个就记一个,就像报数,只不过是递减的报数。 | 是水闸,线程执行就像水流动,水闸处停止,直至水满(线程都运行完毕)才开始泄流。 |
宿管阿姨,晚上关宿舍大门睡觉,需要等到所有学生回寝,才能关门睡觉,学生之间不用相互等待,回寝就能睡觉。 | 家庭聚餐,等待家庭成员到齐才能开饭,家庭成员之间需要相互等待,直到最后一个到达,才能同时开饭。 |
两者使用侧重点不同,但CountDownLatch在某些时候是可以和CyclicBarrier互换的,如果要用CountDownLatch代替CyclicBarrier那么必须在每个线程的操作完成之后调用CountDown方法。 |