浅谈java锁底层原理AQS

浅谈java锁底层原理AQS

背景

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

AQS

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

你可能感兴趣的:(java)