从ReentrantLock到AQS源码阅读

ReentrantLock是使用AQS实现的一种可重入的独占锁,并且提供了公平和非公平两种策略。
从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(公平锁)的加锁过程。

上一篇:Go语言syncMap LoadOrStore


下一篇:async await:比requests 更强大