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