本文内容及代码参考视频:https://www.bilibili.com/video/BV1ta4y1H73X/?spm_id_from=333.788.recommend_more_video.-1 ReentrantLock是Java开发中最常用到的组件之一,简单来说,可以把ReentrantLock理解为基于AQS所实现的公平锁与非公平锁,用于实现对共享资源对象的同步。它和synchronized关键字一样支持可重入,但在调度上相较于synchronized更加的灵活。接下来我们从其内部继承和功能实现上来对其进行详解。本文内容基于AQS的基础上讲解,如果对AQS不了解请先了解AQS的内容。
1.ReentrantLock的内部结构
ReentrantLock的源码定义如下:
public class ReentrantLock implements Lock, java.io.Serializable
我们可以看出,ReentrantLock是Lock接口的一个实现类,那它必然就会对Lock接口中定义的方法进行了实现,下面我们先看一下Lock接口中都定义了哪些方法:
public interface Lock {
//尝试获取锁,如果锁被占有则等待获取
void lock();
//与lock类似,区别在于当前线程等待锁时,如果被中断,则直接抛出中断异常
void lockInterruptibly() throws InterruptedException;
//尝试获取锁,无论成功与否都直接返回
boolean tryLock();
//规定尝试获取所得时间
boolean tryLock(long time, TimeUnit unit) throws InterruptedException;
//解锁
void unlock();
//为当前lock绑定一个Condition对象
Condition newCondition();
}
我们可以看出Lock接口中主要定义了加锁,解锁,锁中断和锁关联条件这几个方法,那么ReentrantLock中具体是怎么实现这些方法的呢?在了解这些具体的实现之前,我们不妨先来看一看ReentrantLock中都有哪些值的注意的内部属性:
private final Sync sync;
其实ReentrantLock类内部只有一个内部属性,就是Sync类型的sync,它的初始化是在ReentrantLock初始化时候传入的,代码如下:
public ReentrantLock() {
sync = new NonfairSync();
}
public ReentrantLock(boolean fair) {
sync = fair ? new FairSync() : new NonfairSync();
}
我们可以看出ReentrantLock在初始化时,如果不传入值,会默认构造一个NonfairSync()实例赋值,而如果传入值则会根据传入值构造NonfairSync()或FairSync()实例,而