JVM运行时数据区分为线程私有和共享区域:程序计数器记录字节码地址,是唯一不发生OOM的区域;虚拟机栈存储方法执行信息,可能抛出StackOverflowError或OutOfMemoryError;本地方法栈服务native方法;Java堆为对象实例分配空间,是GC主要区域,内存不足抛出OOM;方法区存储类信息、常量等,JDK8后元空间替代永久代;运行时常量池属方法区,支持动态添加常量;直接内存通过NIO使用,不受堆限制但受本地内存限制。

JVM 运行时数据区是 Java 虚拟机在执行 Java 程序时管理内存的区域划分。这些区域各自承担不同的职责,协同完成程序的运行。主要分为线程私有和线程共享两大部分。
线程私有区域
这些区域随线程创建而创建,随线程销毁而销毁,每个线程独有。
- 程序计数器(Program Counter Register):记录当前线程所执行的字节码指令的地址。如果执行的是 Java 方法,计数器保存的是正在执行的虚拟机字节码指令的地址;如果是本地方法,则计数器值为 undefined。这个区域是唯一不会发生 OutOfMemoryError 的区域。
- Java 虚拟机栈(Java Virtual Machine Stacks):每个线程私有的栈,描述 Java 方法执行的内存模型。每次方法调用都会创建一个栈帧(Stack Frame),用于存储局部变量表、操作数栈、动态链接、方法返回地址等信息。栈的大小可以是固定或动态扩展,若线程请求的栈深度大于虚拟机允许的最大深度,会抛出 StackOverflowError;若无法申请足够内存,会抛出 OutOfMemoryError。
- 本地方法栈(Native Method Stack):与虚拟机栈类似,但服务的是本地(native)方法。有些 JVM 实现(如 HotSpot)将两者合二为一。
线程共享区域
这些区域被所有线程共享,随虚拟机启动而创建,随虚拟机退出而销毁。
发卡宝是一个专业的软件卡密等虚拟商品在线交易平台,拥有多种兑换方式,费率低,结算快,正规企业平台一直稳定运营,24小时不间断提供自动发卡服务。【模板说明】试用版自带一套模板(响应式)【环境支持】PHP环境 / 200M或以上空间大小 / 开启父路径 / 设置index.php为默认首页 / 目录写入权限需要开启【数据库】MySQL【安装步骤】将文件上传至空间目录,运行“http://域名/inst
- Java 堆(Java Heap):所有线程共享的一块区域,用于存放对象实例和数组。它是垃圾回收的主要区域,通常也被称为“GC 堆”。堆可以是物理上不连续的空间,只要逻辑上连续即可。堆内存不足时会抛出 OutOfMemoryError。
- 方法区(Method Area):用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码缓存等。在 JDK 8 之前,使用永久代(Permanent Generation)实现;JDK 8 及以后,用元空间(Metaspace)替代,元空间使用本地内存(Native Memory),避免了永久代常见的内存溢出问题。
- 运行时常量池(Runtime Constant Pool):是方法区的一部分,用于存放编译期生成的各种字面量和符号引用。这部分内容会在类加载后进入方法区的运行时常量池。它具备动态性,可以在运行期间添加新的常量,比如调用 String 的 intern() 方法。
直接内存(Direct Memory)
虽然不属于 JVM 运行时数据区的规范部分,但经常被使用。通过 NIO 中的 ByteBuffer.allocateDirect() 分配的内存就是直接内存,它位于本地内存中,不受 Java 堆大小限制,但受本机总内存限制。频繁使用可能导致本地内存溢出(OutOfMemoryError)。
基本上就这些。理解这些区域有助于排查内存问题,比如栈溢出、堆溢出、元空间溢出等,也能更好掌握 GC 和性能调优的原理。









