zoukankan      html  css  js  c++  java
  • 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的基石,后面会详细剖析这个类。

  • 相关阅读:
    JavaScript + HTML 虚拟键盘效果
    HTML + JS随机抽号。
    JavaScript 鼠标划过 播放音乐。
    JavaScript 笔记
    HTML5 div+css导航菜单
    div错位/解决IE6、IE7、IE8样式不兼容问题
    HTML5-表单的创建
    HTML5-布局的使用
    HTML5-块元素标签的使用
    HTML5-列表的使用
  • 原文地址:https://www.cnblogs.com/Jaxlinda/p/7111316.html
Copyright © 2011-2022 走看看