• 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的基石,后面会详细剖析这个类。

  • 相关阅读:
    OCP-1Z0-053-V12.02-40题
    OCP-1Z0-053-V12.02-255题
    OCP-1Z0-053-V12.02-407题
    OCP-1Z0-053-V12.02-298题
    OCP-1Z0-053-V12.02-38题
    OCP-1Z0-053-V12.02-274题
    OCP-1Z0-053-V12.02-159题
    OCP-1Z0-053-V12.02-406题
    OCP-1Z0-053-V12.02-369题
    OCP-1Z0-053-V12.02-610题
  • 原文地址:https://www.cnblogs.com/Jaxlinda/p/7111316.html
Copyright © 2020-2023  润新知