锁升级过程

5 篇文章 0 订阅
2 篇文章 0 订阅

*锁升级(优化)锁升级的过程

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

  1. 无锁:首先是一个无锁的状态,代表着里面不涉及到锁,什么时候是无锁的状态呢,就是写了一个synchronized将一个对象锁住(写了一个对象),此时没有任何线程去访问这个对象,此时这个对象就是无锁状态,此时没有线程访问它

  2. 偏向锁升级原理
    当线程1访问代码块并获取锁对象时,会在java对象头和栈顿中记录偏向的锁的threadID,因为偏向锁不会主动释放锁
    因此以后线程1再次获取锁的时候,需要比较当前线程的threadID和Java对象头中的threadID是否一致,如果一致(还是线程1获取锁对象);
    如果不一致(其他线程,如线程2要竞争锁对象,而偏向锁不会主动释放因此还是存储的线程1的threadID),那么需要查看Java对象头中记录的线程1是否存活:

    -如果没有存活,那么锁对象被重置为无锁状态,其它线程(线程2)可以竞争将其设置为偏向锁;

    -如果存活,那么立刻查找该线程(线程1)的栈帧信息,如果还是需要继续持有这个锁对象,那么暂停当前线程1,据销偏向锁,升级为轻量级锁,如果线程1不再使用该锁对象,那么将锁对象状态设为无锁状态,重新偏向断的线程。

  3. 轻量级锁原理和升级过程
    线程1获取轻量级锁时会先把锁对象的对象头MarkWord复制一份到线程1的栈帧中创建的用于存储锁记录的空间(称为DisplacedMarkWord);
    然后使用CAS把对象头中的内容音换为线程1存储的锁记录(DisplacedMarkWord)的地址;
    如果在线程1复制对象头的同时《在线程1CAS之前》,线程2也准备获取锁,复制了对象头到线程2的领记承空间中,但是在线程2CAS的时候,发现线程1已经把对象头换了,线程2的CA5失败,那么线程2就尝试使用*白旋锁**来等待线程1释放锁。自旋领简单来说就是让线程2在循环中不断CAS

  4. 重量级锁升级原理
    ·但是如果自旋的时间太长也不行,因为自旋是要消耗CPU的,因此自旋的次数是有限制的,比如10次或者100次,如果自旋次数到了线程1还没有释放锁,或者线程1还在执行,线程2还在自旋等待,这时又有一个线程3过来竞争这个锁对象,那么这个时候轻量级锁就会膨胀为重量级锁。重量级锁把除了拥有锁的线程都阻塞,防止CPU空转。
    •轻量级锁是指当锁是偏向锁的时候,却被另外的线程所访问,此时偏向锁就会升级为轻量级锁,其他线程会通过自旋(关于自旋的介绍见文末)的形式尝试获取锁,线程不会阻塞,从而提高性能。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值