【Java面试】什么是JVM内存分配担保机制?

简介: 【Java面试】什么是JVM内存分配担保机制?
JVM内存分配担保机制,如果想要理解透彻,需要先知道,Java GC是什么时候发生的?

Java GC When Happend?

Java 虚拟机一般采用的是分代回收策略,即把对象分为两代,新生代和老年代,新生代又分为Eden区和两个Survivor区,比例为8:1:1。
1)新建的对象(除了大数据对象)会首先分配在Eden区,如果Eden区空间不够时,就会发生一次Minor GC
2)当新生代的对象进入老年代时,如果老年代的空间不够时,就会发生一次Full GC,大对象一般会直接进入老年代,为了防止在Eden、Survivor区中copy带来的性能消耗
3)每次发生Minor GC时,Java虚拟机会检测老年代的剩余空间是否大于新生代的总空间,如果大于,则直接发生MinorGC,而且操作是安全的。如果小于,那么此时就引入了内存担保的概念

JVM内存分配担保机制

谁承担了这个角色
从上面GC发生的时刻来说,需要内存分配担保的时候,我们知道老年代存当了担保的角色。

如何承担的?
从上面第三点MinorGC发生的时候,检测到老年代剩余空间小于新生代的总空间,也就说,这次如果恰好新生代里面的对象都到了晋升年龄,那么都要进入老年代,此时老年代的空间不够了。怎么办?
此时Java虚拟机会去查看HandlePromotionFailure设置值是否允许担保失败。如果HandlePromotionFailure=true,那么会继续检查老年代最大可用连续空间是否大于历次晋升到老年代的对象的平均大小,如果大于,则尝试进行一次Minor GC,但这次Minor GC依然是有风险的;如果小于或者HandlePromotionFailure=false,则改为进行一次Full GC。

为什么需要内存分配担保呢?
是因为新生代采用复制收集算法,假如大量对象在Minor GC后仍然存活(最极端情况为内存回收后新生代中所有对象均存活),而Survivor空间是比较小的,这时就需要老年代进行分配担保,把Survivor无法容纳的对象放到老年代。老年代要进行空间分配担保,前提是老年代得有足够空间来容纳这些对象,但一共有多少对象在内存回收后存活下来是不可预知的,因此只好取之前每次垃圾回收后晋升到老年代的对象大小的平均值作为参考。使用这个平均值与老年代剩余空间进行比较,来决定是否进行Full GC来让老年代腾出更多空间。

目录
相关文章
|
5天前
|
缓存 安全 Java
7张图带你轻松理解Java 线程安全,java缓存机制面试
7张图带你轻松理解Java 线程安全,java缓存机制面试
|
1天前
|
消息中间件 Java Linux
2024年最全BATJ真题突击:Java基础+JVM+分布式高并发+网络编程+Linux(1),2024年最新意外的惊喜
2024年最全BATJ真题突击:Java基础+JVM+分布式高并发+网络编程+Linux(1),2024年最新意外的惊喜
|
3天前
|
算法 Java Python
【Python 的内存管理机制专栏】Python 内存管理实战:性能优化与内存泄漏检测
【5月更文挑战第18天】Python内存管理关乎程序性能与稳定性。优化包括避免过多临时对象,如优化列表推导式减少对象创建。警惕循环引用造成的内存泄漏,如示例中的Node类。使用`gc`模块检测泄漏,通过`gc.set_debug(gc.DEBUG_LEAK)`和`gc.collect()`获取信息。实践中需持续分析内存使用,优化算法、数据结构和资源释放,以提升程序质量与效率。
【Python 的内存管理机制专栏】Python 内存管理实战:性能优化与内存泄漏检测
|
3天前
|
存储 Java 程序员
【Python 的内存管理机制专栏】深入解析 Python 的内存管理机制:从变量到垃圾回收
【5月更文挑战第18天】Python内存管理关乎程序性能与稳定性,包括变量存储和垃圾回收。变量存储时,如`x = 10`,`x`指向内存中值的引用。垃圾回收通过引用计数自动回收无引用对象,防止内存泄漏。了解此机制可优化内存使用,避免循环引用等问题,提升程序效率和稳定性。深入学习内存管理对成为优秀Python程序员至关重要。
【Python 的内存管理机制专栏】深入解析 Python 的内存管理机制:从变量到垃圾回收
|
3天前
|
算法 安全 程序员
深入理解操作系统的内存管理机制
【5月更文挑战第18天】 在现代计算领域,操作系统的内存管理是确保系统高效稳定运行的关键。本文将详细探讨操作系统内存管理的核心概念、技术及其实现细节。通过分析虚拟内存、物理内存、分页、分段以及内存分配策略等要素,我们揭示了操作系统如何优化内存使用,保证安全性和提供多任务支持。此外,文中还将评估现代操作系统面临的内存管理挑战,如碎片化、内存泄露和虚拟化技术的应用。
|
5天前
|
存储 API Android开发
Android 11 中的存储机制更新,面试心得体会
Android 11 中的存储机制更新,面试心得体会
|
5天前
|
NoSQL 算法 Java
【redis源码学习】持久化机制,java程序员面试算法宝典pdf
【redis源码学习】持久化机制,java程序员面试算法宝典pdf
|
5天前
|
Java 数据库连接 Spring
K8S+Docker理论与实践深度集成java面试jvm原理
K8S+Docker理论与实践深度集成java面试jvm原理
|
6天前
|
存储 缓存 算法
深入浅出JVM(二)之运行时数据区和内存溢出异常
深入浅出JVM(二)之运行时数据区和内存溢出异常
|
6天前
|
Java Linux Arthas
linux上如何排查JVM内存过高?
linux上如何排查JVM内存过高?
792 0