文章列表

满足什么条件时,一个 Java 类会被卸载?

本文深度解析Java类被卸载的三大条件:类的所有实例被回收、加载该类的ClassLoader被回收、Class对象无引用。详解原理、代码示例及热部署场景下的类泄漏问题,助你掌握JVM类生命周期与元空间内存管理。

CMS 的底层原理是什么?优势在哪?

本文深度解析CMS垃圾回收器的底层原理,详细拆解初始标记、并发标记、重新标记、并发清除等六大工作步骤,分析其低延迟优势及对CPU敏感、浮动垃圾、内存碎片等劣势,并探讨CMS在JDK版本中的演进与替代方案。

CMS 和 G1 垃圾回收器的区别是什么?

本文深度解析CMS和G1垃圾回收器的核心区别。从堆内存布局、回收算法(标记-清除 vs 标记-整理)、停顿模型、并发机制到适用场景全面对比,并剖析CMS的碎片化问题与G1的可预测停顿优势,助你掌握JVM低延迟回收器选型与调优要点。

OOM 引起原因以及如何排查?

本文深度解析OOM(OutOfMemoryError)的常见原因,涵盖Java堆、元空间、栈/线程、直接内存等区域溢出场景,并系统介绍排查方法与工具链(堆转储、MAT分析、jstat监控、jmap直方图等)。结合代码示例与最佳实践,助你快速定位内存问题,提升线上故障处理能力。

JVM 运行时内存区域如何划分的?

本文深度解析JVM运行时内存区域的划分,包括线程私有的程序计数器、Java虚拟机栈、本地方法栈,以及线程共享的堆、方法区(JDK8后元空间取代永久代)。详解每个区域的作用、存储内容、异常类型,并延伸至直接内存与最佳实践,助你掌握JVM内存管理核心。

什么是 AOT 编译?和 JIT 有什么区别?

本文深度解析AOT编译与JIT编译的核心区别。从编译时机、启动速度、峰值性能、内存占用、动态特性支持等维度全面对比,并分析各自适用场景(传统后端 vs Serverless/云原生),结合GraalVM Native Image与HotSpot JVM,助你理解Java执行技术演进与选型。

什么是 Class 常量池,和运行时常量池区别是什么?

本文深度解析Class常量池与运行时常量池的核心区别。从.class文件的静态结构到JVM运行时内存的加载过程,详解两者的定义、存储位置、产生时机及动态性,并结合javap命令与String.intern()示例,助你彻底理解这一JVM高频考点。

什么情况会导致 JVM 退出?

本文深入解析JVM退出的各种原因,涵盖正常退出(非守护线程结束)、主动调用System.exit()/Runtime.halt()、致命错误(如OOM)以及外部信号(SIGTERM/SIGKILL)等场景。详解守护线程机制、关闭钩子的执行条件与优雅停机实践,助你全面掌握JVM生命周期与线上稳定性知识。

YoungGC 和 FullGC 的触发条件是什么?

本文深入解析Young GC和Full GC的触发条件。详解Young GC由Eden区满触发,Full GC则涉及老年代空间不足、元空间满、System.gc()调用及CMS/G1等收集器的特有场景。结合GC日志分析与调优建议,助你掌握JVM核心知识。

JVM 中一次完整的 GC 流程是怎样的?

本文深入解析JVM中一次完整的GC流程,涵盖Minor GC、Major GC/Full GC的触发条件与执行过程,详解对象分配与晋升机制(年龄阈值、动态年龄判断、空间分配担保),并对比Parallel、CMS、G1、ZGC等收集器的流程差异。附GC日志示例与常见误区,助你彻底掌握JVM垃圾回收核心。