偏向锁是JVM为减少单线程反复加锁开销而设计的优化机制,通过对象头Mark Word记录线程ID实现零成本重入,仅在发生竞争时撤销或升级锁。

偏向锁是JVM在无竞争场景下为减少同步开销而设计的一种锁优化机制。它的核心目的不是“防竞争”,而是“省操作”——当一个对象几乎总是被同一个线程反复加锁时,直接跳过所有同步逻辑,让该线程近乎零成本地进入同步块。
在JDK 1.6之前,哪怕只有一个线程反复执行synchronized代码块,每次都要走完整的锁获取流程(比如CAS尝试、检查锁状态等),这会带来不必要的CPU开销和指令路径复杂度。偏向锁把“这个锁大概率只归我用”这一事实提前登记下来,后续访问就变成一次简单的ID比对,连CAS都不需要。
关键依赖对象头里的Mark Word。当线程第一次获取锁时:
整个过程不涉及操作系统互斥量,纯JVM层面完成,所以极快。
立即学习“Java免费学习笔记(深入)”;
一旦有第二个线程尝试获取同一把锁,偏向锁就必须让位:
撤销本身有代价——要停线程、遍历栈帧、更新对象头。因此,频繁竞争反而会让偏向锁拖慢性能。
不是所有同步都适合开启偏向锁。它最有效的情况是:
像Web请求中每个请求新建对象并短暂加锁、或高频并发修改共享计数器这类场景,偏向锁基本无效,甚至建议用-XX:-UseBiasedLocking关闭。
基本上就这些。偏向锁不是万能钥匙,它是JVM在“大概率单线程”假设下做的性能妥协,理解它的适用边界比记住流程更重要。
以上就是Java中偏向锁是做什么的_Java偏向锁运行机制说明的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号