JUC--ReenTrantLock学习(三)源码分析之释放锁

1 概述

通过前面一篇文章(JUC--ReenTrantLock学习(二)源码分析之获取锁)我们已经学习了ReenrantLock获取锁的相关知识,这里我们将要学习ReenTrantLock释放锁的内容。下面我们直接开始源码的学习。

2 源码分析

首先,我们依然来看一下释放锁unlock的调用流程。

(1)unlock

 public void unlock() {
        //直接调用AQS的release
        sync.release(1);
    }

(2)release

//此方法为模板方法,最终会调用子类的基本方法tryRelese来实现锁释放
public final boolean release(int arg) {
        if (tryRelease(arg)) {
            Node h = head;
            if (h != null && h.waitStatus != 0)
                
                //唤醒后继节点
                unparkSuccessor(h);
            return true;
        }
        return false;
    }

(3)tryRelease

protected final boolean tryRelease(int releases) {

            //减掉releases
            int c = getState() - releases;

            //如果释放的不是持有锁的线程,直接抛出异常
            if (Thread.currentThread() != getExclusiveOwnerThread())
                throw new IllegalMonitorStateException();
            boolean free = false;

            //status==0表示已经释放,其余线程可以进行锁获取
            if (c == 0) {

                //设置空闲状态为true
                free = true;

                //置空持有锁的线程
                setExclusiveOwnerThread(null);
            }
            setState(c);
            return free;
        }

上面就是针对ReentrantLock释放锁的源码分析,后面将继续学习JUC下面的其余工具类。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值