news 2026/5/26 18:23:12

深度理解 Java synchronized —— 从原理到实战

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
深度理解 Java synchronized —— 从原理到实战


文章目录

  • 一、synchronized 的作用
      • `synchronized` 解决两个问题:
  • 二、synchronized 的三种使用方式
    • ✔ 1. 修饰实例方法(锁 —— 当前对象 this)
    • ✔2. 修饰静态方法(锁 —— 当前类的 Class 对象)
    • ✔3. 修饰代码块(锁 —— 任意对象)
  • 三、synchronized 的底层原理(Monitor 机制)
    • ✔1. synchronized 基于对象监视器(Monitor)实现
  • 四、锁的升级过程(JDK 6 后重要优化)
  • 五、可见性是如何保证的?
  • 六、synchronized 与 Reentrant(可重入性)
  • 七、synchronized 与 volatile 的区别(面试高频)
  • 八、synchronized 的优缺点
  • 九、synchronized VS Lock(面试必考)
  • 十、实战

一、synchronized 的作用

synchronized是 Java 提供的最基础、最核心的线程同步机制,用来保证多线程环境下的互斥访问可见性
虽然简单易用,但其背后的锁原理(Monitor)、对象头(Mark Word)、锁升级(偏向锁→轻量级锁→重量级锁)等概念极其重要,也是面试高频考点。

synchronized解决两个问题:

  1. 互斥性(Mutual Exclusion)
    保证同一时刻只有一个线程可以执行临界区代码。
  2. 可见性(Visibility)
    保证释放锁前对共享变量的修改对下一个获得锁的线程可见(类似 volatile 的效果)。

二、synchronized 的三种使用方式

✔ 1. 修饰实例方法(锁 —— 当前对象 this)

publicsynchronizedvoidtest(){// 临界区}

等价于:

publicvoidtest(){synchronized(this){// 临界区}}

特点:

  • 作用于:同一个对象实例
  • 多个线程访问不同对象时不会互斥

✔2. 修饰静态方法(锁 —— 当前类的 Class 对象)

publicstaticsynchronizedvoidtest(){// 临界区}

等价于:

synchronized(MyClass.class){// 临界区}

特点:

  • 锁住的是类对象,所有实例共享一把锁

✔3. 修饰代码块(锁 —— 任意对象)

Objectlock=newObject();synchronized(lock){// 临界区}

特点:

  • 最灵活
  • 推荐在实际开发中优先使用
  • 可以对任何对象加锁(Object、String 等)

三、synchronized 的底层原理(Monitor 机制)

✔1. synchronized 基于对象监视器(Monitor)实现

Java 中,每一个对象都可以作为锁,因为:

  • 每个对象在 JVM 中都有一个对象头(Object Header)
  • 对象头中包含锁状态(Mark Word)
  • synchronized 通过 Monitor(监视器锁)实现互斥

四、锁的升级过程(JDK 6 后重要优化)

Java 的锁不是一开始就用重量级锁,而是逐步升级,以提升性能。

锁类型特点适用场景
无锁无竞争单线程
偏向锁无需 CAS,完全无竞争同一线程反复进入
轻量级锁使用 CAS,自旋少量竞争
重量级锁阻塞/唤醒,最慢竞争激烈

⚠️注意事项:

  • 锁只能从低级到高级升级
  • 不会降级(重要)

五、可见性是如何保证的?

当一个线程释放锁时,JVM 会做两件事:

  1. 把工作内存的变量刷新到主内存(释放锁 → 写回)
  2. 获得锁的线程会从主内存重新读取变量

因此保证:

  • 前一个线程修改的数据对后一个线程可见

六、synchronized 与 Reentrant(可重入性)

synchronized可重入锁
同一线程可以多次获得同一把锁不会死锁。

publicsynchronizedvoida(){b();// 可以再次获得同一把锁}publicsynchronizedvoidb(){// ...}

七、synchronized 与 volatile 的区别(面试高频)

对比synchronizedvolatile
可见性
原子性有(加锁)没有
是否阻塞会阻塞不阻塞
用途多个操作的原子性单变量读写
底层Monitor、锁升级内存屏障、禁止指令重排

volatile 解决可见性,synchronized 解决原子性 + 可见性。


八、synchronized 的优缺点

✔优点

  • 语法简单
  • JVM 层面保证,没有死锁风险(可重入)
  • 经过大量优化(锁消除、偏向锁)性能已大幅提升

✔缺点

  • 粒度不够灵活(无条件等待)
  • 性能比 Lock 略弱(尤其在高并发中)
  • 无法进行尝试锁 / 中断锁 / 超时锁 等操作

九、synchronized VS Lock(面试必考)

特性synchronizedLock
锁的释放自动释放必须 unlock()
可中断
可尝试✔(tryLock)
公平锁
条件队列✔(Condition)
性能被优化后差别不大更灵活,高并发优势明显

十、实战

建议 1:优先使用 synchronized(JDK 8 性能已非常好)
建议 2:优先锁代码块,而不是锁整个方法
建议 3:锁对象要私有,避免被外部使用

privatefinalObjectlock=newObject();

建议 4:避免锁住字符串常量(共享跨 ClassLoader)

synchronized("LOCK"){}// ❌ 千万不要这样写


参考资料

深入理解Java中synchronized三种使用方式:助您写出线程安全的代码-知乎

synchronized - 指南 - ljbguanli - 博客园

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/22 5:02:30

MinerU终极指南:一站式PDF智能解析完整教程

还在为PDF文档的结构化解析而头疼吗?面对复杂的学术论文、技术文档或商业报告,传统OCR工具往往无法准确识别版面结构、表格内容和数学公式,导致信息提取不完整、格式混乱等问题。MinerU作为一款开源的高质量PDF解析工具,专门解决这…

作者头像 李华
网站建设 2026/5/24 7:22:43

企业级Android SDK管理实战:从下载到CI/CD集成

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个企业级Android SDK管理工具,支持:1) 多版本SDK并行管理;2) 团队共享SDK仓库功能;3) 与Jenkins/GitLab CI的深度集成&#xf…

作者头像 李华
网站建设 2026/5/12 15:55:31

DBeaver连接MySQL效率提升300%的5个技巧

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个DBeaver效率优化工具。功能:1) 连接响应时间测试 2) SSH隧道自动配置 3) 连接池参数优化建议 4) 网络延迟诊断 5) 生成优化报告。通过AI分析历史连接数据给出个…

作者头像 李华
网站建设 2026/5/22 4:40:45

RT-Thread开发新姿势:AI自动生成嵌入式代码

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 基于RT-Thread操作系统开发一个温湿度监测系统,使用STM32F103芯片和DHT11传感器。要求:1.创建两个线程,分别负责传感器数据采集和LCD显示&#x…

作者头像 李华
网站建设 2026/5/22 4:24:27

从零到发布:Prism框架如何提升WPF开发效率3倍

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个对比演示项目,展示使用Prism框架与传统WPF开发的效率差异:1.基础框架搭建时间对比,2.添加新功能模块的步骤对比,3.实现跨模块…

作者头像 李华
网站建设 2026/5/15 9:13:54

小白必看:Visual C++ 2015运行库安装图解指南

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个交互式教学应用,通过动画和分步指导帮助用户理解Visual C 2015运行库的作用。应用应包含自动检测功能,引导用户完成下载和安装过程。设计要简洁直观…

作者头像 李华