CountDownLatch和CyclicBarrier简单比较:
CountDownLatch
CyclicBarrier
软件包
java.util.concurrent
java.util.concurrent
适用情景
主线程等待多个工作线程结束
多个线程之间互相等待,直到所有线程达到一个障碍点(Barrier point)
主要方法
CountDownLatch(int count) (主线程调用)
初始化计数
CountDownLatch.await (主线程调用)
阻塞,直到等待计数为0解除阻塞
CountDownLatch.countDown
计数减一(工作线程调用)
CyclicBarrier(int parties, Runnable barrierAction) //初始化参与者数量和障碍点执行Action,Action可选。由主线程初始化
CyclicBarrier.await() //由参与者调用
阻塞,直到所有线程达到屏障点
等待结束
各线程之间不再互相影响,可以继续做自己的事情。不再执行下一个目标工作。
在屏障点达到后,允许所有线程继续执行,达到下一个目标。可以重复使用CyclicBarrier
异常
如果其中一个线程由于中断,错误,或超时导致永久离开屏障点,其他线程也将抛出异常。
其他
如果BarrierAction不依赖于任何Party中的所有线程,那么在任何party中的一个线程被释放的时候,可以直接运行这个Action。
If(barrier.await()==2)
{
//do action
}