JVM的GC垃圾回收面试小结

本文详细讲解了JVM的核心组件,如虚拟机栈、本地方法栈等,并剖析了线程共享和私有的内存结构。此外,介绍了垃圾回收的触发条件、内存溢出与泄漏的区别,以及对象引用与内存释放机制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、JVM的组件有什么?
答:jvm主要包含5个核心结构:虚拟机栈,本地方法栈,堆,方法区,程序计数器。

2、JVM中哪些结构是线程共享的,哪些是线程私有的?
答:线程共享的有堆(保存新建的实例),方法区(主要保存存一些静态常量,基本类型变量)。
线程私有的是虚拟机栈,本地方法栈还有线程计数器。

3、JVM中的虚拟机栈帧中保存了什么?
答:虚拟机栈帧中保存了局部变量表,动态链接,操作数栈,方法返回地址

4、gvm做垃圾回收的时候什么时候触发full gc什么时候触发senior gc?
答:说触发fullgc和senior gc前首先得明确两个概念:(1)什么是gc垃圾回收,gc垃圾回收主要发生在jvm的堆中,堆又被分为新生代,老年代,元空间(持久带),新生代里又被划分为3个区域,eden区,from区和to区,(2)什么被对象被gc认为是垃圾,有两种方法确认可达性分析法和引用计数器,当通过可达性分析法找到的对象不认为是垃圾,找不到引用的被认为是垃圾,引用计数器是当引用次数为0时被认为是垃圾。
明确以上两个概念后再谈谈什么时候触发full gc 什么时候触发senior gc。新建的实例首先出现在edan区当无法在eden区创建新的实例时,eden区和form区会经过可达性算法分析后将不活跃的实例对象回收,释放空间,这就是触发了一次senior gc(值得一提的是在此处采用的是复制回收的垃圾回收算法,统一将eden区和from区的活跃对象复制到to区,然后回收不活跃对象)。那么什么时候触发full gc呢?这个分为比较多的情况

  1. 当调用System.gc()时,系统会要求触发full gc,但是不一定执行
  2. 当老年代没有空间了,则会触发一次full gc。
  3. 当从新生代经过8次(默认)senior gc存活下来的对象向老年代移动时,老年代空间不足以接收新生代对象时,触发full gc。
  4. 方法区空间不足
  5. 当新生代想老年代转移空间大小平均大于老年代剩余空间时触发full gc。

5、当内存中变量A引用了变量B,JVM是如何释放内存呢?
答:这里涉及两个内存回收的算法,一个是引用计数法,另一个是可达分析法。引用计数法对于这种情况是处理不了的,得用可达性分析法:通过一系列称为“GC Roots”的对象作为起始点,从这些节点开始向下搜索,搜索走过的路径称为“引用链”,当一个对象到 GC Roots 没有任何的引用链相连时(从 GC Roots 到这个对象不可达)时,证明此对象不可用。这里可达性分析法可以解决这种循环引用的情况。

6、内存溢出与内存泄漏的区别是什么?
答:1、内存溢出是指你要求分配的内存吗,系统给不了你了。空间不足。
2、内存泄漏是指程序在申请内存后,无法释放已申请的内存空间,一次内存泄露危害可以忽略,但内存泄露堆积后果很严重,无论多少内存,迟早会被占光。

以下是几个 JVM 垃圾回收相关的面试题及其答案: 1. 什么是垃圾回收垃圾回收是指在程序运行过程中,自动回收不再使用的内存空间,以提高内存利用率和程序的性能。 2. JVM垃圾回收机制是什么? JVM垃圾回收机制采用分代收集算法,将内存分为新生代和老年代,分别采用不同的垃圾回收算法来回收内存。 3. 新生代垃圾回收器有哪些? 新生代垃圾回收器主要有 Serial、ParNew、Parallel Scavenge 等。 4. 老年代垃圾回收器有哪些? 老年代垃圾回收器主要有 Serial Old、Parallel Old、CMS、G1 等。 5. 什么是对象的引用计数算法? 引用计数算法是一种简单的垃圾回收算法,它通过记录每个对象被引用的次数,当引用次数为 0 时,即可将该对象回收。 6. 引用计数算法的缺点是什么? 引用计数算法的缺点是无法处理循环引用的情况,如果两个对象之间相互引用,它们的引用计数会一直不为 0,导致无法回收。 7. 什么是标记-清除算法? 标记-清除算法是一种常见的垃圾回收算法,它将垃圾回收分为两个阶段:标记阶段和清除阶段。在标记阶段,标记所有活跃对象,将其打上标记;在清除阶段,清除所有未标记的对象。 8. 标记-清除算法的缺点是什么? 标记-清除算法的缺点是会产生大量的内存碎片,会导致内存利用率降低。 以上是一些常见的 JVM 垃圾回收面试题及其答案,希望能对你有所帮助。在面试过程中,需要根据具体的问题进行回答,同时也需要对垃圾回收机制和算法有清晰的认识,才能更好地回答相关的问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值