浅谈java锁底层原理AQS

浅谈java锁底层原理AQS

背景

之前了解java锁的时候,只知道通过什么api能获得锁,可是对具体怎么获得锁及锁是什么并没深入了解,现在就深入聊聊锁,我们以ReentrantLock锁为例

AQS

先上AQS的类图
在这里插入图片描述
AQS队列同步器,这个类我们关注state属性和node类,state属性表示同步的状态0表示没锁,大于等于1表示锁被持有.node类大家可以自己看下类结构,这个是双向链表的结构!
在看看lock()方法具体干了啥,还是先上个类图
在这里插入图片描述
上面的图是我个人debug后画出来的类调用,调用过程我简单的解释下:
当线程第一次调用lock()获取锁的时候,会通过cas,判断当前state是不是0,是0说明该锁没有被其他线程持有,就会把当前线程对象赋值给独占锁(AbstractOwnableSynchronizer 里面的成员变量exclusiveOwnerThread),然后把state变成1,说明该锁已经被线程持有!同样的锁释放也就是把state从1变成0,把独占锁对象重新设为空,大家可以自己debug尝试理解下哦!个人觉得debug是程序员自学源码了解底层实现最有效的方式!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值