堆内存分区

内容概述

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

相关推荐
祎雪双十Gy2 小时前
从 DataX 的配置加载说起:我用 FastJson2 做了一个轻量级动态配置管理库
java·后端
小锋java12342 小时前
分享一套锋哥原创的SpringBoot4+Vue3宠物领养网站系统
java
考虑考虑5 小时前
Java实现hmacsha1加密算法
java·后端·java ee
掉鱼的猫6 小时前
Spring Boot → Solon 注解迁移实战指南:一张对照表说清楚
java·spring boot
plainGeekDev6 小时前
广播接收器 → Flow + Lifecycle
android·java·kotlin
plainGeekDev6 小时前
EventBus → SharedFlow
android·java·kotlin
带刺的坐椅6 小时前
Spring Boot → Solon 注解迁移实战指南:一张对照表说清楚
java·springboot·web·solon
用户3721574261356 小时前
Java 将一个 PPT 文档拆分为多个文件
java
人活一口气1 天前
Spring Boot与AIGC的完美结合:从零搭建智能内容生成平台
java·spring boot·aigc
像我这样帅的人丶你还1 天前
Java 后端详解(三):全局异常处理与 JPA 数据库映射
java·后端