JVM堆内存中新生代晋升到老年代的条件

1. 一般年龄判断

当对象在Eden区中经过第一次 Minor GC 后,如果仍然存活,则会被移动到 From Survivor 区,并且对象的年龄设为 1。每经过一次 Minor GC,存活下来的对象年龄加 1,若存活对象在 From Survivor 区的年龄达到阈值(一般为 15 岁),则会晋升到老年代。

虚拟机并不是永远地要求对象年龄必须达到了-XX:MaxTenuringThreshold=15才能晋升老年代;

2. 动态年龄判断

动态年龄判断: Survivor区的对象年龄从小到大进行累加,当累加到X年龄(某个年龄)时占用空间的总和大于50%(可以使用-XX:TargetSurvivorRatio=?来设置保留多少空闲空间,默认值是50),那么比X年龄大的对象都会晋升到老年代;

3. 大对象

定义大对象的大小的参数是 -XX:PretenureSizeThreshold ,它表示对象在超过这个阈值时将会直接分配到老年代,而不经过新生代。这个参数的默认值可以根据具体的虚拟机版本和配置进行调整,一般情况下默认值是 0,即所有对象都将在新生代分配。

4. 空间担保机制

执行 Minor GC 之前,会先判断老年代的可用空间是否大于新生代的全部空间,如果大于会直接执行 Minor GC,小于会判断老年代的可用空间是否大于 晋升到老年代的平均大小;如果小于,则直接执行 FULL GC 再进行Minor GC;如果大于则尝试执行一次 Minor GC,在尝试进行 Minor GC 的过程中,会看看老年代是否放得下,放不下,就先执行一次 FULL GC 然后再执行 Minor GC。

ps:以下是我整理的java面试资料,密码是obht,感兴趣的可以看看。最后,创作不易,觉得写得不错的可以点点关注!

链接:https://www.yuque.com/u39298356/uu4hxh?# 《Java面试宝典》

相关推荐
KaMeidebaby5 小时前
卡梅德生物技术快报|PD1 单克隆抗体定制配套 N 糖全谱质控开发
前端·人工智能·算法·数据挖掘·数据分析
8Qi86 小时前
LeetCode 235. 二叉搜索树的最近公共祖先(LCA)
算法·leetcode·二叉树·递归·二叉搜索树·lca·迭代
bIo7lyA8v6 小时前
算法稳定性分析中的随机扰动建模的技术8
算法
科研online6 小时前
基于多源数据和XGBoost-SHAP分析中国大陆绿地碳汇空间变异影响因素的非线性相关性与尺度差异
算法·学习方法
Cthy_hy7 小时前
拓扑排序超详解:原理 + Kahn 贪心算法
python·算法·贪心算法
三品吉他手会点灯7 小时前
C语言学习笔记 - 43.运算符与表达式 - 运算符1 - 运算符的分类和简单介绍
c语言·笔记·学习·算法
心之伊始7 小时前
Java 后端接入大模型:从 Token、并发到推理成本的完整估算方法
java·spring boot·性能优化·大模型·llm
VkN2X2X4b7 小时前
算法复杂度的实验验证与误差分析的技术8
算法
其利天下技术8 小时前
风扇灯无刷电机自适应算法实战指南
算法·cocos2d·无刷电机自适应算法·bldc驱动自适应算法·其利无刷电机驱动算法
8Qi88 小时前
LeetCode 494:目标和(Target Sum)—— 题解 ✅
算法·leetcode·职场和发展·动态规划·01背包