JVM内存模型分为程序计数器、虚拟机栈、本地方法栈、堆、方法区(元空间)五部分;前三个线程私有,后两个线程共享,各自承担指令执行、方法调用、对象存储、类元数据管理等职责,是理解GC、OOM等问题的基础。

Java JVM内存模型,指的是JVM在运行时划分的几块逻辑内存区域,每块区域有明确职责、生命周期和线程可见性。它不是物理内存映射,而是JVM规范定义的“运行时数据区”,是理解GC、OOM、栈溢出、类加载等问题的基础。
程序计数器:每个线程的“下一条指令坐标”
它是线程私有的小内存空间,记录当前线程正在执行的字节码指令地址(如分支跳转、循环继续都靠它)。执行Native方法时值为undefined。这个区域不会OOM——因为只存一个固定长度的地址值,占用极小,由CPU寄存器直接支持。
虚拟机栈:方法调用的骨架容器
每个线程启动时自动创建,生命周期与线程一致。每次调用方法,就压入一个栈帧;方法返回,栈帧弹出。一个栈帧包含:
- 局部变量表:存放方法参数和内部定义的变量(如int a = 5存在slot0)
- 操作数栈:临时存放计算中间结果,比如a + b先压a、再压b、再执行iadd
- 动态链接:指向方法区中该方法的类元数据,支撑多态调用
- 方法返回地址:记录正常退出或异常退出后要跳转的位置
堆:所有对象的唯一归属地
线程共享,JVM启动时创建,是内存中最大的一块。所有new出来的对象实例、数组都分配在这里。堆又细分为:
立即学习“Java免费学习笔记(深入)”;
- 新生代:含Eden区 + 两个Survivor区(S0/S1),新对象优先进Eden
- 老年代:长期存活的对象(如缓存、大对象)最终晋升至此
- 元空间(JDK8+):取代永久代,存放类元信息(Class结构、常量池、静态变量等),使用本地内存,不属堆
堆是GC主要发生地,也是OutOfMemoryError: Java heap space的根源区域。
方法区与元空间:类的“户籍档案馆”
线程共享,存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码。JDK7及以前叫“永久代”,JDK8起改用“元空间”,直接使用本地内存(即系统RAM),不再受JVM堆大小限制。字符串常量池在JDK7后从方法区移到了堆中。
基本上就这些。五大部分——程序计数器、虚拟机栈、本地方法栈、堆、方法区(元空间)——构成了JVM运行时的完整内存视图。画图时注意区分“线程私有”和“线程共享”,这是理解并发、GC、内存泄漏的关键起点。










