堆内存分区

内容概述

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标记后直接清除不移动对象

相关推荐
Devin~Y18 小时前
大厂Java面试实战:Spring Boot微服务、Redis缓存、Kafka消息队列与Spring AI RAG
java·spring boot·redis·kafka·mybatis·spring mvc·hikaricp
RSTJ_162518 小时前
PYTHON+AI LLM DAY FIFITY-ONE
开发语言·人工智能·python
qingfeng1541518 小时前
企业微信定时群发实战:API 如何实现批量消息自动发送?
java·开发语言·python·自动化·企业微信
丁劲犇18 小时前
QodeAssist:为msys2 ucrt64 Qt Creator 注入 AI 灵魂的开源插件
开发语言·人工智能·qt
qingfeng1541518 小时前
企业微信 API 可以做什么?
java·开发语言·python·自动化·企业微信
梧桐和风18 小时前
2026 年 Java 趋势:AI 浪潮下,Java 会过时吗?
java·开发语言·人工智能
lsx20240618 小时前
React 组件详解
开发语言
Hesionberger18 小时前
LeetCode105:前序中序构建二叉树(三解法)
java·数据结构·python·算法·leetcode·深度优先
嗨嗨的迷子18 小时前
JDK 17 远程调试连不上 5005:从 attach timeout 到 JDWP 监听地址变更
java·开发语言
Chase_______19 小时前
【Java杂项】为什么 long 可以自动转 float?宽化基本类型转换与精度丢失详解
java·开发语言·python