AbstractQueuedSynchronizer: 抽象队列同步器。
Java并发包下的所有同步类都是基于这个类来实现的。
ReentrantLock lock = new ReentrantLock(); // 非公平锁
ReentrantLock lock = new ReentrantLock(true); // 公平锁
// 多个线程过来,都尝试加锁
lock.lock();
// 执行代码
lock.unlock();
AQS加锁过程:
- 线程1、线程2同时执行
进行加锁。lock.lock()
- 同时使用CAS更新AQS中state的值为1,假如线程1更新成功,将加锁线程的值设置为线程1;此时线程2更新state失败,加锁失败,进入等待队列。
- 线程1执行完后释放锁,会将state值设置为0,同时会唤醒等待队列中的线程来进行加锁操作。
- 等待队列中的线程想要进行加锁操作,也要通过CAS更新state值为1方式进行加锁的,如果这时一个线程也正在CAS更新state值进行加锁,并且更新state值为1成功加锁,等待队列里的线程会更新state值失败加锁失败,再次进入等待队列,体现了AQS默认实现是非公平锁。
- 想要实现公平锁,当一个线程在加锁的时候,如果等待队列不为空,直接进入等待队列排队加锁。