锁在java虚拟机中的实现和优化

  1. 偏向锁 思想:若某一锁被线程获取后,便进入偏向模式,当线程再次请求这个锁是,无需再进行相关的同步操作,从而节省了操作时间。 偏向锁使用于竞争不激烈的情况,在竞争激烈的情况下,会导致持有锁的线程不停地切换,锁也很难一直保持在偏向模式,此时,不仅得不到性能的优化,反而有可能降低系统性能。
  2. 轻量级锁 如果偏向锁失败,Java虚拟机会让线程申请轻量级锁。
  3. 锁膨胀 当轻量级锁失败,虚拟机就会使用重量级锁。
  4. 自旋锁 自旋锁可以使线程在没有取得锁时,不被挂起,而转而去执行一个空虚幻(即所谓的自旋),在若干个空循环后,线程如果可以获得锁,则继续执行。若线程依然不能获得锁,才会被挂起。 注意:适用于竞争不激烈的情况下,对于锁竞争激烈,单线程锁占用时间长的并发程序,自旋锁在自旋等待后,往往依然无法获得对应的锁,不仅仅拜拜浪费了CPU时间,最终还是免不了执行被挂起的操作,反而浪费了系统资源。
  5. 锁消除 锁消除是Java虚拟机在JIT编译时,通过对运行上下文的扫描,去除不可能存在共享资源竞争的锁。通过锁消除,可以节省毫无意义的请求锁时间。比如,开发人员在没有锁竞争的代码中用了JDK内置的线程安全类:StringBuffer,Vector等。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值