java面试提高班2-Synchronized 加锁原理

锁升级过程

无锁 -> 偏向锁 -> 轻量级锁 -> 重量级锁

image.png

锁升级原理图

synchronized 加锁原理.png

无锁 -> 偏向锁

线程T1请求synchronized同步对象O,检查对象O存储的线程是否为T1,若是,无需CAS加锁解锁,继续执行同步代码块;若否,检查对象O存储的线程是否存活,若否,重置对象O为无锁,线程T1竞争得到偏向锁

偏向锁 -> 轻量级锁

此时对象O存储的为线程T1,线程T2也来竞争锁,检查线程T1是否要继续持有锁,若否,重置对象O为无锁,线程T2可竞争得到偏向锁;若继续持有,暂停T1线程,撤销偏向锁,升级为轻量级锁

轻量级锁 -> 重量级锁

线程T1获取轻量级锁时,先将对象O的对象头Mark word 拷贝一份到线程T1在栈帧中创建的存储锁记录空间,然后使用CAS操作把对象头中内容替换为线程T1的存储记录;若线程T1执行复制操作时,线程T2也尝试获取锁,复制对象头到T2的锁记录空间,此时T1已经CAS完成,T2的CAS操作失败,T2尝试自旋方式继续尝试获取锁,自旋次数达到最大阈值时,或者此时线程T3也来竞锁,轻量级锁升级重量级锁;未获得锁的T2、T3将会阻塞,减少CPU空转。

Mark word 对象头

image.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值