1、 CyclicBarrier可以重复使用,而CountdownLatch不能重复使用。
2、 Java的concurrent包里面的CountDownLatch其实可以把它看作一个计数器,只不过这 个计数器的操作是原子操作,同时只能有一个线程去操作这个计数器,也就是同时只能有一个 线程去减这个计数器里面的值。
3、 你可以向CountDownLatch对象设置一个初始的数字作为计数值,任何调用这个对象上的 await()方法都会阻塞,直到这个计数器的计数值被其他的线程减为0为止。
4、 所以在当前计数到达零之前,await方法会一直受阻塞。之后,会释放所有等待的线程, await的所有后续调用都将立即返回。这种现象只出现一次一一计数无法被重置。如果需要重 置计数,请考虑使用CyclicBarrier。
5、 CountDownLatch的一个非常典型的应用场景是:有一个任务想要往下执行,但必须要等
到其他的任务执行完毕后才可以继续往下执行。假如我们这个想要继续往下执行的任务调用一 个CountDownLatch对象的await()方法,其他的任务执行完自己的任务后调用同一个 CountDownLatch对象上的countDown()方法,这个调用await()方法的任务将一直阻塞等待, 直到这个CountDownLatch对象的计数值减到0为止。
CyclicBarrier 一个同步辅助类,它允许一组线程互相等待,直到到达某个公共屏障点 (common barrier point)。在涉及一组固定大小的线程的程序中,这些线程必须不时地互相等 待,此时CyclicBarrier很有用。因为该barrier在释放等待线程后可以重用,所以称它为 循环的barrier。
Was this helpful?
0 / 0