Java synchronized和lock锁

2024-06-25  本文已影响0人  jecyhw

synchronized和lock锁区别

synchronized实现原理

synchronized锁是基于对象实现的,对象存储在堆中,每个对象会有一个对象头,对象头里面会有一个markword来记录当前锁的一个状态:无锁(匿名偏向)、偏向锁、轻量级锁、重量级锁。

锁升级过程:当线程访问synchronized同步代码块时,会先尝试加偏向锁,如果加成功直接返回;失败就说明当前已经有别的线程获取了锁,就会尝试升级成轻量级锁,线程会使用cas自旋一定次数来获取锁,如果还是获取锁失败就会升级成重量级锁,此时线程就会进入block状态。

在jdk1.6之前,synchronized只有重量级锁。在jdk1.6之后增加了锁升级的机制,另外还增加了锁消除和锁膨胀的优化:

lock实现原理

lock底层是基于AQS实现。AQS是抽象队列同步器,是一个用来构建锁和同步器的框架。

AQS关键数据结构

加锁过程

释放锁过程

线程使用cas的方式将state减1,如果state等于0,表示锁释放。唤醒队列第一个线程,唤醒之后队列第一个线程通过cas的方式尝试加锁,一旦加锁成功,就会把自己移除队列,让下一个节点变成对头,然后该线程就可以去执行逻辑了。

AQS唤醒节点时,为何从后往前找第一个节点

因为等待队列添加节点(以及节点取消)时,是先调整新节点的前向指针,再调整tail指针(此时原来tail指针的next指针还是null),最后在调整原来tail的next指针,如果从前往后找,会存在节点丢失(没访问到)的情况。

上一篇 下一篇

猜你喜欢

热点阅读