堆内存分区

内容概述

Java堆通常被划分为新生代老年代两个区域。

  1. 新生代 :绝大多数新创建的对象首先在这里分配内存。新生代内部又分为一个Eden区 和两个Survivor区(From和To)。新对象在Eden区分配。当Eden区没有足够空间进行分配时,将触发一次Minor GC。
  2. 老年代 :在新生代中经历多次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标记后直接清除不移动对象

相关推荐
代码AI弗森1 天前
一文理清楚“算力申请 / 成本测算 / 并发评估”
java·服务器·数据库
Old Uncle Tom1 天前
OpenClaw 记忆系统 -- 记忆预加载
java·数据结构·算法·agent
小小小米粒1 天前
Collection单列集合、Map(Key - Value)双列集合,多继承实现。
java·开发语言·windows
摇滚侠1 天前
expdp 查看帮助
java·数据库·oracle
czhc11400756631 天前
C# 428 线程、异步
开发语言·c#
2401_871492851 天前
Vue.js监听器watch利用回调函数处理级联下拉框数据联动
jvm·数据库·python
:1211 天前
java基础
java·开发语言
SilentSamsara1 天前
Python 环境搭建完整指南:从下载安装到运行第一个程序
开发语言·python
曹牧1 天前
Spring:@RequestMapping注解,匹配的顺序与上下文无关
java·后端·spring
daixin88481 天前
cursor无法正常使用gpt5.5等模型解决方案
java·redis·cursor