AQS原理

一、简介

AQS即AbstractQueuedSynchronizer,中文叫做队列同步器。是用来构建锁或者其他同步组件的基础框架,它使用了一个int成员变量表示同步状态,通过内置的FIFO队列来完成资源获取线程的排队工作。

二、使用AQS构建同步组件

同步器的主要使用方式是继承,子类通过继承同步器并实现它的方法来管理同步状态。子类被推荐被定义为同步组件的静态内部类。

2.1 访问和修改同步状态

  • getState():获取同步状态;

  • setState(int newState):设置当前同步状态;

  • compareAndSetState(int expect, int update):使用CAS设置当前状态,该方法保证状态设置的原子性;

2.2 同步器可重写的方法

  • boolean tryAcquire(int arg):独占式获取同步状态;

  • boolean tryRelease(int arg):独占式释放同步状态;

  • int tryAcquireShared(int arg):共享式获取同步状态;

  • boolean tryReleaseShared(int arg):共享式释放同步状态;

  • boolean isHeldExclusively():当前同步器是否在独占模式下被线程占用,一般该方法表示是否被当前线程所独占。

以上方法不需要全部都实现,根据获取锁的种类可以选择实现不同的方法,支持独占获取锁的同步器应该实现tryAcquire,tryRelease和isHeldExclusively,而支持共享获取的同步器应该实现tryAcquireShared,tryReleaseShared和isHeldExclusively。

下面看一下ReentrantLock的设计:

三、获取锁和释放锁

同样我们对ReentrantLock的加锁和释放锁的源码进行分析,这里我们只分析一下非公平锁的加锁和释放,公平锁类似。

3.1 获取锁

3.2释放锁

Last updated

Was this helpful?