synchronized 的原理(简单版)

synchronized 是 Java 提供的一种 内置锁(互斥锁) ,主要用来保证 多线程访问共享资源时的互斥性和可见性 。它的底层实现依赖 对象头中的 Mark Word 和 Monitor 机制

首先,每个 Java 对象在内存里都有一个 对象头(Object Header) ,其中有一部分叫 Mark Word ,里面会记录锁的信息,比如锁状态、线程 ID 等。当线程进入 synchronized 代码块时,JVM 会尝试修改对象头中的 Mark Word 来获取锁。

在实现上,synchronized 是基于 Monitor(管程)机制 的。每个对象都可以关联一个 Monitor,当线程进入同步代码块时,相当于获取这个对象的 Monitor;如果获取不到,就会进入等待队列,等锁释放后再竞争。

为了提高性能,JVM 对 synchronized 做了 锁优化和锁升级。锁状态一般会经历:

无锁 → 偏向锁 → 轻量级锁 → 重量级锁。

  • 偏向锁:适用于只有一个线程反复进入同步块的场景,不需要每次都竞争锁。
  • 轻量级锁 :当多个线程交替执行时,通过 CAS + 自旋 来尝试获取锁,避免线程阻塞。
  • 重量级锁:如果竞争比较激烈,锁就会升级为重量级锁,线程会被挂起,由操作系统负责调度。

当线程退出 synchronized 代码块时,就会释放锁,并唤醒等待队列中的线程重新竞争锁。

总结来说:

synchronized 的底层核心是 对象头 + Monitor + CAS + 锁升级机制,通过这些机制在保证线程安全的同时尽量减少线程阻塞,提高并发性能。

synchronized 和 ReentrantLock 的区别是什么?

synchronizedReentrantLock 都是 Java 中实现线程同步的 可重入锁,都可以保证多线程访问共享资源时的线程安全,但它们在实现方式和功能上有一些区别。

第一,实现层面不同
synchronizedJava 关键字 ,属于 JVM 层面的锁,底层是通过 对象头的 Mark Word 和 Monitor 机制 实现的。
ReentrantLockJDK 提供的类 ,实现基于 AQS(AbstractQueuedSynchronizer)框架 ,通过 CAS + FIFO 队列 来实现线程的阻塞和唤醒。

第二,获取锁的方式不同
synchronized 在进入同步块时 自动加锁 ,退出同步块时 自动释放锁
ReentrantLock 需要开发者 手动调用 lock()unlock() ,通常需要在 finally 中释放锁,否则可能导致死锁。

第三,功能灵活性不同
ReentrantLock 功能更丰富,例如:

  • 可以实现 公平锁和非公平锁
  • 支持 tryLock() 尝试获取锁
  • 支持 可中断锁 lockInterruptibly()
  • 可以通过 Condition 实现多个等待队列

synchronized 的功能相对简单,只能是 非公平锁,也不能响应中断。

第四,性能方面

在早期 JDK 版本中,ReentrantLock 的性能通常优于 synchronized

但在 JDK1.6 之后synchronized 引入了 偏向锁、轻量级锁、自旋锁等优化机制 ,性能已经和 ReentrantLock 差距不大,在很多场景甚至更好。

最后总结一句:

synchronized 使用简单、由 JVM 自动管理;
ReentrantLock 更灵活、功能更丰富,适合复杂的并发控制场景。

面试最后可以补一句加分总结:

一般情况下 优先使用 synchronized ,代码更简单;

如果需要 公平锁、可中断锁或 tryLock 等高级功能 ,才会选择 ReentrantLock

==========================更精简======================================

synchronized 是 Java 提供的 内置互斥锁 ,用于保证多线程访问共享资源时的 线程安全和可见性 。它的底层主要依赖 对象头中的 Mark Word 和 Monitor 机制实现。

每个 Java 对象都有 对象头(Object Header) ,其中的 Mark Word 会记录锁状态、线程 ID 等信息。当线程进入 synchronized 代码块时,JVM 会尝试修改 Mark Word 来获取锁;如果获取失败,线程就会进入 Monitor 的等待队列,等锁释放后再竞争。

为了提高性能,JVM 对 synchronized 做了 锁优化和锁升级,锁状态一般会经历:

无锁 → 偏向锁 → 轻量级锁 → 重量级锁

偏向锁适用于 单线程重复加锁 ;轻量级锁通过 CAS + 自旋 减少线程阻塞;如果竞争激烈,就会升级为 重量级锁,线程会被挂起,由操作系统调度。

所以总结来说:
synchronized 的核心原理是 对象头 + Monitor + CAS + 锁升级机制

相关推荐
RainCity5 天前
Java Swing 自定义组件库分享(十二)
java·笔记·后端
LinXunFeng12 天前
Obsidian - 使用 Share Note 分享笔记并自部署
前端·笔记·github
闪闪发亮的小星星17 天前
高斯光以及高斯光公式解释
笔记
cqbzcsq17 天前
CellFlow虚拟细胞论文阅读
论文阅读·人工智能·笔记·学习·生物信息
阿米亚波17 天前
【Windows】QEMU 启动 openEuler aarch64/arm64 架构系统 + 离线软件源
linux·windows·经验分享·笔记·架构·arm
自传.17 天前
尚硅谷 Vibe Coding|第三章(1) Claude Code深度使用与进阶技巧 学习笔记
笔记·学习·尚硅谷·vibecoding
.千余17 天前
【C++】模板进阶全解:非类型参数|全特化|偏特化|分离编译完全指南
开发语言·c++·笔记·学习·其他
自传.17 天前
尚硅谷 Vibe Coding|第二章 AI编程工具生态 学习笔记
笔记·学习·ai编程·尚硅谷·vibe coding
秋波。未央17 天前
Java Agent 开发 · Day 1 学习笔记(含作业完整标准答案)
java·笔记·学习
中屹指纹浏览器17 天前
2026指纹浏览器字体指纹、字体渲染偏差检测与全维度虚拟字体池搭建方案
经验分享·笔记