内容概述
Java堆通常被划分为新生代 和老年代两个区域。
- 新生代 :绝大多数新创建的对象首先在这里分配内存。新生代内部又分为一个Eden区 和两个Survivor区(From和To)。新对象在Eden区分配。当Eden区没有足够空间进行分配时,将触发一次Minor GC。
- 老年代 :在新生代中经历多次GC仍然存活的对象会被移动到老年代。老年代的内存空间一般比新生代大,用于存放生命周期长的对象。当老年代空间不足时,会触发Major GC(或Full GC)。

Java 堆的设计核心在于**"弱分代假说"**:绝大多数对象都是朝生夕死的。
新生代 是高频交易区,采用复制算法。Eden 区负责接纳新对象,一旦满载,触发 Minor GC。存活对象被复制到 Survivor 区,Eden 区直接清空。这种"以空间换时间"的策略,保证了 GC 的高效。
老年代则是长期持有账户。对象在新生代经历多次"洗礼"(默认15次)仍未消亡,即被视为"长期资产",晋升至老年代。这里空间大但回收频率低,一旦空间耗尽,将触发昂贵的 Full GC。
思考一下
问题: 如果系统中的所有对象都变成了"长生不老"的长期对象,堆内存会发生什么?
提示: 思考新生代存在的意义,以及 GC 的频率和停顿时间(STW)会如何变化。
Java堆内存设计的核心理论基础是"弱分代假说",该假说的具体内容是什么?
A对象存活时间越长越容易被回收
B老年代空间必须大于新生代空间
C对象回收频率与内存大小成正比
D绝大多数对象都是朝生夕死的
系统监测到Eden区已满载并触发了Minor GC,此时应采取何种回收策略?
A直接清空Eden区所有对象
B将存活对象复制到Survivor区
C将存活对象移入老年代
D标记后直接清除不移动对象