CyclicBarrier之共享锁的理解

今天看到一篇博文里面提到了共享锁,举例有 CyclicBarrier,CoutDownlatch等,就翻了下源码加深下理解,(之前对共享锁的理解没有对应到具体引用类中),看到CoutDownlatch里面用到了aqs基础类的共享锁相关的方法,然而CyclicBarrier里面只用到了ReentrantLock的独占锁,认为作者写的有问题...... 然后又细看了下aqs的源码发现原来是俺之前没理解。。。

 

CyclicBarrier的共享锁不是执行上的所有线程并发去dowait方法,而是所有线程共同等待一个状态,这里的状态正常情况下是count的值,当值等于0时所有阻塞的线程恢复执行,否则线程阻塞。

 

 

CyclicBarrier[saɪklɪkˈbæriə(r)]的共享锁实现:

基于 java.util.concurrent.locks.Condition类:trip(栅栏,阀门的意思);trip.await():获取锁,获取不到则阻塞当前线程,trip.signalAll():释放所有阻塞的线程。

 

 

CoutDownlatch的共享锁实现:

基于java.util.concurrent.locks.AbstractQueuedSynchronizer抽象类的本地实现:sync;acquireSharedInterruptibly:获取锁,获取不到则阻塞当前线程,releaseShared:释放共享锁,满足条件后unpark所有阻塞的线程。

 

Condition也是基于AbstractQueuedSynchronizer实现的,后者是juc的基石,后面会详细剖析这个类。

posted @ 2017-07-03 15:21  Jaxlinda  阅读(581)  评论(0编辑  收藏  举报