贝利信息

JVM内存模型1.8_JDK 1.8版本JVM内存模型特点

日期:2026-01-26 00:00 / 作者:煙雲
JDK 1.8 JVM内存模型核心变化是永久代被元空间取代:元空间使用本地内存而非堆内存,不参与堆GC,由-XX:MetaspaceSize和-XX:MaxMetaspaceSize控制,字符串常量池仍在堆中,运行时常量池移至元空间。

JDK 1.8 的 JVM 内存模型最核心变化是:永久代(PermGen)被彻底移除,由元空间(Metaspace)替代——这不只是换个名字,而是内存归属、GC 行为和调优逻辑的根本性重构。

为什么 Metaspace 不再报 java.lang.OutOfMemoryError: PermGen space

因为元空间不再使用 JVM 堆内存,而是直接分配在本地内存(native memory)中。只要系统物理内存或虚拟内存没耗尽,就不会因“类太多”而触发该错误。

堆内结构没变,但“方法区”的实现逻辑彻底脱离 JVM 堆

新生代(Eden + S0/S1)、老年代、GC 策略这些堆内划分与 JDK 1.7 一致,但“方法区”这个逻辑概念,现在由元空间承载,且它不参与任何堆 GC 周期。

程序计数器、栈、堆仍是线程私有/共享的老样子,但要注意“栈溢出”场景没变

虚拟机栈、本地方法栈、程序计数器这些线程私有区域,在 JDK 1.8 中行为完全不变,StackOverflowErrorOutOfMemoryError 的触发条件也一样。

真正容易被忽略的是:元空间的 GC 不是“自动友好型”,它只在达到 MetaspaceSize 后才尝试回收无用类,且是否成功取决于类加载器是否被回收。如果应用频繁生成类(如大量使用 CGLIB、Groovy 脚本、热部署),又没正确释放 ClassLoader,元空间会持续上涨直到触达 MaxMetaspaceSize 或本地内存极限——这时候看监控,会发现 GC 日志里 Metadata GC Threshold 反复出现,但元空间使用量却下不去。