Java的JVM中的概念之——新生代和老年代

JVM新生代和老年代是JVM中非常重要的概念,那么他们在JVM中扮演者什么样的角色和含义呢?

在Java虚拟机(JVM)的垃圾回收(GC)中,内存被分为不同的区域,其中两个主要区域是新生代(Young Generation)和老年代(Old Generation),它们都属于堆内存(Heap)的一部分。

新生代(Young Generation):新生代是Java虚拟机中用于存放新创建的对象的内存区域。新生代被进一步划分为Eden区和两个Survivor区(通常为From和To区)。新创建的对象首先被分配到Eden区,当Eden区满时,会触发Minor GC(小型垃圾回收),将存活的对象转移到Survivor区。Survivor区也会随着对象存活时间增长而被回收或者晋升到老年代。

老年代(Old Generation) :老年代是Java虚拟机中用于存放长时间存活的对象的内存区域。当对象经过多次Minor GC仍然存活时,它们会被晋升(Promotion)到老年代。老年代的空间较大,用于存放存活时间较长的对象。当老年代空间满时,会触发Major GC(大型垃圾回收)或Full GC(全局垃圾回收),这会涉及到整个堆内存的垃圾回收操作。

新生代和老年代的划分是基于对象的生命周期假设:大多数对象都是短命的,只有少数对象会长时间存活。因此,新生代的空间较小,用于快速回收大量短命对象;而老年代的空间较大,用于存放存活时间较长的对象。这种分代策略可以提高垃圾回收的效率。

除了新生代和老年代之外,还有一个永久代(Permanent Generation)或元空间(Metaspace),这是早期JVM内存结构中的一个区域,用于存储类信息、方法区和常量池等数据。从JDK 8开始,永久代被元空间所取代,元空间并不在Java堆内存中,而是使用本地内存。

相关推荐
小bo波4 小时前
使用Thread子类创建线程 VS 使用Runnable接口创建线程的区别
java·多线程·thread·并发编程·runnable
SamDeepThinking4 小时前
高并发场景下,CompletableFuture与ForkJoinPool该如何取舍?
java·后端·面试
张不才7 小时前
CPU 100% 了怎么办?Java 性能排障的标准化操作
java·后端
shepherd1119 小时前
吞吐量提升 10 倍:高并发大批量数据处理任务的架构演进与性能调优
java·后端·架构
plainGeekDev11 小时前
单例模式 → object 声明
android·java·kotlin
用户2986985301412 小时前
Java 实现 Word 文档文本与图片提取的方法
java·后端
SimonKing13 小时前
铁子,IntelliJ IDEA 2026.1.3来了,升不升?
java·后端·程序员
咖啡八杯1 天前
GoF设计模式——策略模式
java·后端·spring·设计模式
用户128526116021 天前
我把祖传Java项目重构后,接口响应从3s砍到了200ms,只改了这几行代码
java