本文主要是介绍面试题——JVM老年代空间担保机制(我的想法),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
这里借用一下人家的图,来说一下我的想法,嘻嘻。。。。
原文链接:一道面试题:JVM老年代空间担保机制-CSDN博客?
嗯,我觉得老年代担保机制的主要作用就是避免频繁触发FULL GC,这其实也是因为年轻代Minor GC后存活对象大小的不确定性而造成的,整体流程就是当准备Minor GC时,老年代会先提前预估一下,往最坏了想,如果这次年轻代GC后,所有对象都存活下来并且还全都要进入老年代,那我能不能承受住呢,如果行,那么正常执行Minor GC即可,但如果不行,老年代就要判断一下了,参考以往的多次Minor GC后进入老年代对象的大小平均值,如果现在老年代可用空间小于平均值,则直接执行Full GC,但如果现在老年代可用的空间大于平均值,则还是硬着头皮执行Minor GC,如果执行了Minor GC后,老年区的剩余空间是够用的,则一切安好,如果硬着头皮执行Minor GC后,剩余空间是不够的,则还是会执行Full GC。
这就是老年代空间担保的过程,是新生代对象向老年代空间进行担保,看我Moinor GC后,进入老年代对象的总大小,你老年代能不能装的下。
而且老年代的空间担保机制是默认开启的。
这篇关于面试题——JVM老年代空间担保机制(我的想法)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!