AQS与ReentrantLock

AQS与ReentrantLock

AQS抽象队列同步器

AQS利用一个FIFO双向队列(CLH队列的变体)来完成线程同步状态的管理,同步队列的节点包括以下属性(AQS的内部类):

image-20231120154123901

waitStatus的状态:

  • CANCELLED 1 表示线程获取锁的请求已经取消了
  • SIGNAL -1 表示线程已经准备好了,就等资源释放了
  • CONDITION -2 表示节点在等待队列中,节点线程等待唤醒
  • PROPAGATE -3 当前线程处于SHARE情况下,该字段才会使用

资源共享方式:

  • EXCLUSIVE 独占 如:ReentrantLock
  • SHARE 共享 如:Semaphore/CountDownLatch

AQS 使用 int 成员变量 state 表示同步状态,使用volatile关键字保证可见性和有序性,通过内置的FIFO队列来完成获取资源线程的排队工作:

image-20231120160950427

AQS使用了模板方法模式,自定义同步器的时候需要重写以下函数(并不一定全部实现):

//独占方式。尝试获取资源,成功则返回true,失败则返回false。
protected boolean tryAcquire(int)
//独占方式。尝试释放资源,成功则返回true,失败则返回false。
protected boolean tryRelease(int)
//共享方式。尝试获取资源。负数表示失败;0表示成功,但没有剩余可用资源;正数表示成功,且有剩余资源。
protected int tryAcquireShared(int)
//共享方式。尝试释放资源,成功则返回true,失败则返回false。
protected boolean tryReleaseShared(int)
//该线程是否正在独占资源。只有用到condition才需要去实现它。
protected boolean isHeldExclusively()

ReentrantLock

image-20231121170723275

ReentrantLock属于独占锁,其中包含内部类Sync实现了AQS,同时FairSyncNonfairSync继承于Sync分别实现了公平锁和非公平锁。

获取锁过程Lock

整体流程图如下:

image-20231121200611179

释放锁过程unLock

image-20231121201224241

参考资料

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

无知猫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值