爪巴羊男爪巴 2021-12-05 16:43 采纳率: 50%
浏览 22
已结题

关于自旋锁 重量级锁 轻量级锁 的相关问题

已知:
我们在网上查阅资料时会发现,自旋优化是用在轻量级锁中的,当自旋超过n次,则升级为重量级锁.
有一种新的自旋操作是自适应自旋,即根据过往经验,判断自旋判断标准中的n具体为多少.
求解:
现在的问题是既然锁的升级是单向的,那么自适应锁怎么会得到过往经验呢?按理说升级为重量级锁之后就不会再降级为轻量级锁,也就不会再面临自旋次数的选择了.也就是说这个次数的判定只会出现一次,感觉逻辑上出了点问题,希望能得到大家的回答.

  • 写回答

3条回答 默认 最新

  • 爪巴羊男爪巴 2021-12-08 12:52
    关注

    我又重新看了《深入理解java虚拟机》给的定义,"如果在同一个锁对象上,自旋等待刚刚成功获得过锁,并且持有锁的线程正在运行中,那么虚拟机就会认为这次自旋也很有可能再次成功,进而允许自旋等待持续相对更长的时间",我的理解如下:
    这里我原来将一段同步代码块看作一个锁,但实际上在java中锁的单位应该是对象锁或类锁,也就是说,一个对象锁可能对应很多同步代码块,当然,由于我们编程的习惯以及代码本身来说,用同一把锁锁住的代码块往往具有相似性,也就是应用场景相似,所以可以借用上次的经验,这个过程中是同一个线程和同一个对象(对象锁)的对应关系,并不是从上一个线程获得的经验。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)
编辑
预览

报告相同问题?

问题事件

  • 系统已结题 12月15日
  • 已采纳回答 12月8日
  • 创建了问题 12月5日
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部