• 奈学:reaseShared共享式释放锁


    共享锁的释放是通过调用releaseShared模版方法来实现的。大概步骤为:
    1. 调用tryReleaseShared尝试释放共享锁,这里必须实现为线程安全。
    2. 如果释放了锁,那么调用doReleaseShared方法环迅后继结点,实现唤醒的传播。
    对于支持共享式的同步组件(即多个线程同时访问),它们和独占式的主要区别就是tryReleaseShared方法必须确保锁的释放是线程安全的(因为既然是多个线程能够访问,那么释放的时候也会是多个线程的,就需要保证释放时候的线程安全)。由于tryReleaseShared方法也是我们自己实现的,因此需要我们自己实现线程安全,所以常常采用CAS的方式来释放同步状态。
    /**
    * 共享模式下释放锁的模版方法。
    * ,如果成功释放则会调用
    */
    public final boolean releaseShared(int arg) {
    //tryReleaseShared释放指锁
    if (tryReleaseShared(arg)) {
    //释放成功,必定调用doReleaseShared尝试唤醒后继结点
    doReleaseShared();
    return true;
    }
    return false;
    }
    本文来源于:奈学开发者社区,如有侵权,请联系我删除~
  • 相关阅读:
    数据库里面的表空间,用户在实际开发中的使用
    并行编程的模型机制
    临时表在开发中的使用

    HIbernate编程模型
    网络数据如何可靠传输
    Spring Security编程模型
    java的缓存框架
    sort函数使用自定义数据排序使用
    FailOver的机制
  • 原文地址:https://www.cnblogs.com/Jss-forever/p/13525302.html
Copyright © 2020-2023  润新知