Java岗大厂面试百日冲刺 - 日积月累,每日三题【Day35】—— JVM2(1)

总结

面试建议是,一定要自信,敢于表达,面试的时候我们对知识的掌握有时候很难面面俱到,把自己的思路说出来,而不是直接告诉面试官自己不懂,这也是可以加分的。

以上就是蚂蚁技术四面和HR面试题目,以下最新总结的最全,范围包含最全MySQL、Spring、Redis、JVM等最全面试题和答案,仅用于参考

一份还热乎的蚂蚁金服面经(已拿Offer)面试流程4轮技术面+1轮HR

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

在这里插入图片描述

对于java开发者来说gc是一个双刃剑,像C语言的垃圾回收是人工的,工作量大,但是可控性高。而java是自动化的,但是可控性很差,甚至有时会出现内存溢出的情况,内存溢出也就是jvm分配的内存中对象过多,超出配置的JDK最大可分配内存的大小


在这里插入图片描述

课间休息,又来秀一下来自咱们群里同学的搬砖工地,坐标:武汉

作者:相识何必再相逢


面试题2:JVM会在什么时候进行GC呢?

===================================================================================

JVM常在以下几种场景时进行GC操作:

  • 在cpu空闲的时候自动进行回收

  • 主动调用System.gc()后尝试进行回收,是否回收由JVM决定。

  • Eden区域满了,或者新创建的对象大小 > Eden所剩空间,执行Minor GC

  • 升到老年代的对象大于老年代剩余空间的时候执行Full GC,或者Young GC中发生promotion failure`强制Full GC 。

  • 在堆内存存储满了之后进行GC,如gc与非gc时间耗时超过了GCTimeRatio的限制引发OOM

YGC出现promotion failure的场景: promotion failure发生在Young GC, 如果Survivor区当中存活对象的年龄达到了设定值,会就将Survivor区当中的对象拷贝到老年代,如果老年代的空间不足,就会发生promotion failure, 强制进行Full GC 。

追问1:介绍一下不同代空间的垃圾回收机制


新生代(Young generation):

从年轻代空间(包括 Eden 和 Survivor 区域)回收内存被称为 Minor GC,因为 Java 对象大多都具备朝生夕灭(很快不再使用)的特性,所以 Minor GC 非常频繁,一般回收速度也比较快。这一定义既清晰又易于理解。。

老年代(Old generation):

对象没有变得不可达,并且从新生代周期中存活了下来,会被拷贝到这里。其区域分配的空间要比新生代多。也正由于其相对大的空间,发生在老年代的GC次数要比新生代少得多。清理老年代内存一般直接是 Full GC来清理。

默认的新生代(Young generation)、老年代(Old generation)所占空间比例为 1 : 2

持久代(Permanent generation):

也称之为方法区(Method area):用于保存类常量以及字符串常量。注意,这个区域不是用于存储那些从老年代存活下来的对象,这个区域也可能发生GC。发生在这个区域的GC事件为 Major GC 。

出现了 Major GC,经常会伴随至少一次的 Minor GC(但非绝对的,ParallelScavenge 收集器的收集策略里就有直接进行 Major GC 的策略选择过程) 。MajorGC 的速度一般会比 Minor GC 慢 10倍以上。只不过在这个区域发生GC的条件非常严苛,必须符合以下三种条件才会被回收:

  1. 所有实例被回收

  2. 加载该类的ClassLoader 被回收

  3. Class 对象无法通过任何途径访问(包括反射)

追问2:能说一下新生代空间的构成与执行逻辑么?


新生代(Young generation)用来保存那些第一次被创建的对象,它被分成三个空间:

  • 一个伊甸园空间(Eden)

  • 两个幸存者空间(From Survivor、To Survivor)

默认新生代空间的分配:Eden : From : To =8 : 1 : 1

在这里插入图片描述

每个空间的执行说明如下:

  1. 绝大多数刚刚被创建的对象会存放在伊甸园空间(Eden)。当一个对象被判定为 死亡 的时候,GC 就有责任来回收掉这部分对象的内存空间。

  2. 新生代是 GC 最频繁区域。当对象在 Eden ( 包括一个 Survivor 区域,假设是 from 区域 ) 出生后,在经过一次 Minor GC后,如果对象还存活,并且能够被另外一块 Survivor 区域所容纳(上面已经假设为 from 区域,这里应为 to 区域,即 to 区域有足够的内存空间来存储 Eden 和 from 区域中存活的对象 ),则使用复制算法将这些仍然还存活的对象复制到另外一块 Survivor 区域 ( 即 to 区域 )中,然后清理所使用过的 Eden以及 Survivor 区域 ( 即from 区域 ),并且将这些对象的年龄设置为1。可见,两个幸存者空间,必须有一个是保持空的

  3. 此后,对象在 Survivor 区每熬过一次 Minor GC,就将对象的年龄 + 1,当对象的年龄达到某个值时 ( 默认是 15 岁,可以通过参数 -XX:MaxTenuringThreshold 来设定),这些对象就会成为老年代

  4. 但也有例外的,对于一些较大的对象 (即需要分配一块较大的连续内存空间 ) 则是直接进入到老年代。。

如何判定对象死亡:通过引用计数法、可达性分析算法判断是否还存在引用,以及结合根据对象引用强度判断;


以下流程评论区朋友们有歧义,经查证确实是有问题的,保留下来引以为戒。

  1. 绝大多数刚刚被创建的对象会存放在伊甸园空间(Eden)。

  2. 在伊甸园空间执行第一次GC(Minor GC)之后,存活的对象被移动到其中一个幸存者空间(Survivor)。

  3. 此后,每次伊甸园空间执行GC后,存活的对象会被堆积在同一个幸存者空间。

  4. 当一个幸存者空间饱和,还在存活的对象会被移动到另一个幸存者空间。然后会清空已经饱和的哪个幸存者空间,可见,两个幸存者空间,必须有一个是保持空的。

  5. 在以上步骤中重复N次(N = MaxTenuringThreshold(年龄阀值设定,默认15))依然存活的对象,就会被移动到老年代。

当然,也有例外出现,对于一些比较大的对象(需要分配一块比较大的连续内存空间)则直接进入到老年代。一般在Survivor 空间不足的情况下发生。


追问3:说一下发生OOM时,垃圾回收机制的执行流程。


  1. 对于一个很大的对象或数组,我们会首先在Eden 尝试创建,如果Eden区内存不够,创建不了,则触发Minor GC

  2. Minor GC完成后继续尝试在Eden区存放,发现仍然放不下;

  3. 尝试直接进入老年代,老年代也放不下

  4. 触发 FULL GC 清理老年代的空间

  5. FULL GC完成后尝试往老年代里放,还是放不下

  6. OOM


在这里插入图片描述

北漂铁子们,快来猜猜这是哪里?

作者:淘气的小苹果


面试题3:Full GC 、Major GC和 Minor GC有什么不同

最后

2020年在匆匆忙忙慌慌乱乱中就这么度过了,我们迎来了新一年,互联网的发展如此之快,技术日新月异,更新迭代成为了这个时代的代名词,坚持下来的技术体系会越来越健壮,JVM作为如今是跳槽大厂必备的技能,如果你还没掌握,更别提之后更新的新技术了。

更多JVM面试整理:

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

pphKR6D-1715296769632)]

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值