ReentrantLock是使用AQS实现的一种可重入的独占锁,并且提供了公平和非公平两种策略。
ReentractLock的内部类Sync继承了AbstractQueuedSynchronizer抽象类,并且提供了两个内部类FairSync和NonfairSync(即公平锁与非公平锁的落地实现),而具体采用哪一种加锁策略则则是由ReentractLock的构造函数进行指定。
public ReentrantLock() {
sync = new NonfairSync();
}
public ReentrantLock(boolean fair) {
sync = fair ? new FairSync() : new NonfairSync();
}
从上面的构造函数可以看到ReentrantLock默认使用的是非公平锁,传入true启用公平锁,传入false则是非公平锁
public void lock() {
sync.lock();
}
从加锁的过程来看,lock方法调用了sync的lock方法,而Sync为抽象类,没有实现lock方法
// Sync类的lock方法
abstract void lock();
那么ReentrantLock的lock方法一定调用的是其子类NonfairSync或FairSync类的lock方法(也就是说加锁的过程与ReentractLock采用的策略有关系),首先分析FairSync(公平锁)的加锁过程。