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

1 概述

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

2 源码分析

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

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

(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下面的其余工具类。

    原文作者:JUC
    原文地址: https://blog.csdn.net/ONROAD0612/article/details/81982468
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞