真实面经题目 · 原创解析

synchronized 锁升级的过程是什么?

synchronized 锁升级的过程是什么?这道腾讯牛客题的关键是围绕“synchronized 锁升级过程”讲清概念、机制、取舍和边界。synchronized 锁升级是 JVM 为不同竞争强度优化 monitor 成本的过程,常见路径是无锁、偏向锁、轻量级锁、重量级锁。现代 JVM 版本对偏向锁支持有所变化,但面试回答仍要说明锁状态随竞争变化而升级。

出现于:腾讯 · 客户端

60 秒回答模板

可以这样回答:synchronized 锁升级是 JVM 为不同竞争强度优化 monitor 成本的过程,常见路径是无锁、偏向锁、轻量级锁、重量级锁。现代 JVM 版本对偏向锁支持有所变化,但面试回答仍要说明锁状态随竞争变化而升级。 无竞争时可以偏向某个线程,后续同线程进入成本很低;出现其他线程竞争时撤销偏向,尝试用 CAS 和栈上锁记录形成轻量级锁;竞争加剧或自旋失败后膨胀为重量级锁,线程阻塞等待 monitor。 偏向和轻量级锁降低低竞争同步成本,但撤销和自旋也有开销。重量级锁会进入阻塞和唤醒路径,吞吐和延迟更受上下文切换影响。 不要把锁升级说成公平锁选择。锁状态通常只能逐步膨胀,不会在同一竞争周期随意降级;具体策略也会随 JDK 版本变化。 验证时重点看:验证时看锁竞争、线程 BLOCKED、上下文切换、JFR/async-profiler 锁事件、接口尾延迟和 JDK 版本下的锁优化配置。

考点 考点边界
主线 核心机制
易错点 把 synchronized 锁升级回答成公平锁/非公…

深入解析

01

考点边界

这题问 synchronized 锁状态优化,不是公平锁或普通 JUC 对比。回答要围绕对象头 Mark Word、CAS、偏向、轻量级、自旋和重量级 monitor 展开。 本题对应“synchronized 锁升级过程”,核心前提是:synchronized 锁升级是 JVM 为不同竞争强度优化 monitor 成本的过程,常见路径是无锁、偏向锁、轻量级锁、重量级锁。现代 JVM 版本对偏向锁支持有所变化,但面试回答仍要说明锁状态随竞争变化而升级。

02

核心机制

无竞争时可以偏向某个线程,后续同线程进入成本很低;出现其他线程竞争时撤销偏向,尝试用 CAS 和栈上锁记录形成轻量级锁;竞争加剧或自旋失败后膨胀为重量级锁,线程阻塞等待 monitor。 关键证据要落到线程状态、锁队列、内存可见性、运行时指标,这样才能说明机制为什么能支撑题目结论。如果继续展开,要对应到线程状态、锁队列、CAS 失败、内存可见性、GC Roots、线程 dump 或运行时指标。

03

关键取舍

偏向和轻量级锁降低低竞争同步成本,但撤销和自旋也有开销。重量级锁会进入阻塞和唤醒路径,吞吐和延迟更受上下文切换影响。 因此要结合线程状态、锁等待、内存可见性、GC 或运行时指标判断,而不是只比较 API 名称。 这些取舍决定了方案在不同输入规模、延迟、内存、并发、泛化或一致性要求下是否仍然成立。

04

边界风险

不要把锁升级说成公平锁选择。锁状态通常只能逐步膨胀,不会在同一竞争周期随意降级;具体策略也会随 JDK 版本变化。 排查时优先看 jstack、GC 日志、heap dump、锁等待、CAS 失败、线程池队列和业务超时。 需要特别关注极端输入、数据分布变化、资源不足、并发竞争或观测口径错误带来的退化。修复时要先拿到线程 dump、GC 或 heap 证据,再区分锁竞争、对象泄漏、线程池耗尽和配置不合理。

05

验证抓手

验证时要看锁等待时间、线程状态、CAS 失败率、重试次数、死锁日志、数据库锁等待、吞吐和尾延迟。能把抽象锁策略落到这些信号,答案才像真实工程排查。 针对本题,最有价值的验证信号是:验证时看锁竞争、线程 BLOCKED、上下文切换、JFR/async-profiler 锁事件、接口尾延迟和 JDK 版本下的锁优化配置。把验证抓手说出来,可以让答案从知识点延伸到并发行为、线程状态和运行时排查。

易错点

  • 把 synchronized 锁升级回答成公平锁/非公平锁,偏离 JVM monitor 优化。
  • 只背状态名称,不说明 Mark Word、CAS、自旋、阻塞和竞争强度的关系。
  • 把相邻概念混用,没有明确说明这道题真正考察的边界。
  • 没有给出验证方式,导致答案听起来完整但无法判断是否真的生效。

面试官追问

轻量级锁为什么适合低竞争场景?

它主要依赖 CAS 和线程栈上的锁记录,避免直接阻塞唤醒线程。只要竞争短暂,自旋或快速 CAS 成功的成本就低于重量级 monitor。

什么时候会膨胀成重量级锁?

当多个线程竞争明显、自旋失败或需要阻塞等待时,锁会膨胀为重量级 monitor,等待线程挂起并由 JVM/OS 唤醒,成本更高但避免无效自旋。

“synchronized 锁升级的过程是什么”继续追问时最该补哪条边界?

应该围绕“synchronized 锁升级过程”补适用前提、失败场景和验证证据。先说明哪些条件下这个机制成立,再说明哪些输入规模、并发状态、数据分布或资源限制会让答案需要调整。

“synchronized 锁升级的过程是什么”怎样回答才不是只背概念?

看它能否把“synchronized 锁升级过程”的机制链路、关键取舍和可观测信号连起来。回答时应落到具体状态变化、数据路径、复杂度、指标或排查工具,而不是只复述定义。

“synchronized 锁升级的过程是什么”选择锁策略先看什么?

先看冲突概率、临界区长度、是否允许重试、重试是否幂等,以及业务更看重吞吐还是公平性。冲突低可以偏向乐观策略,冲突高或强一致临界区通常要更明确地排队或阻塞。