JVM面试题

前言

大部分截图来自于javaguide、库森和路人张,本人只做一些阅读补充
javaguide地址
库森地址
路人张来自公众号面经pdf
视频课程学习

什么是类加载器,常见的类加载器有哪些?

在这里插入图片描述

什么是双亲委派模型?为什么需要双亲委派模型?

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

java异常体系

在这里插入图片描述

如何判断一个对象是否存活?

在这里插入图片描述在这里插入图片描述
在这里插入图片描述即使在可达性分析算法中不可达的对象,也并非是“非死不可”的,这时候它们暂时处于“缓刑”阶段,要真正宣告一个对象死亡,至少要经历再次标记过程。
标记的前提是对象在进行可达性分析后发现没有与GC Roots相连接的引用链。
1).第一次标记并进行一次筛选。
筛选的条件是此对象是否有必要执行finalize()方法。
当对象没有覆盖finalize方法,或者finzlize方法已经被虚拟机调用过,虚拟机将这两种情况都视为“没有必要执行”,对象被回收。

2).第二次标记
如果这个对象被判定为有必要执行finalize()方法,那么这个对象将会被放置在一个名为:F-Queue的队列之中,并在稍后由一条虚拟机自动建立的、低优先级的Finalizer线程去执行。这里所谓的“执行”是指虚拟机会触发这个方法,但并不承诺会等待它运行结束。这样做的原因是,如果一个对象finalize()方法中执行缓慢,或者发生死循环(更极端的情况),将很可能会导致F-Queue队列中的其他对象永久处于等待状态,甚至导致整个内存回收系统崩溃。
Finalize()方法是对象脱逃死亡命运的最后一次机会,稍后GC将对F-Queue中的对象进行第二次小规模标记,如果对象要在finalize()中成功拯救自己----只要重新与引用链上的任何的一个对象建立关联即可,譬如把自己赋值给某个类变量或对象的成员变量,那在第二次标记时它将移除出“即将回收”的集合。如果对象这时候还没逃脱,那基本上它就真的被回收了。
流程图如下:

在这里插入图片描述

强引用、软引用、弱引用、虚引用是什么,有什么区别?

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述在这里插入图片描述

### 关于 JVM 面试题的常见问题及其解析 #### 1. **JVM 内存结构** JVM 的内存主要分为堆、方法区、栈、本地方法栈以及程序计数器五个部分。其中,堆是垃圾回收的主要区域,被划分为新生代和老年代[^1]。 ```java // 新生代中的对象分配演示 public class ObjectAllocation { public static void main(String[] args) { byte[] allocation1, allocation2; allocation1 = new byte[2 * 1024 * 1024]; // 对象可能进入 Eden 区 allocation2 = new byte[2 * 1024 * 1024]; // 如果空间不足,则触发 Minor GC } } ``` #### 2. **GC 过程与算法** 常见的垃圾收集算法有标记-清除法、复制法、标记-整理法以及分代收集法。在实际应用中,通常会采用 CMS 或 G1 收集器来优化性能[^1]。 #### 3. **类加载机制** JVM 类加载过程包括加载、验证、准备、解析和初始化阶段。双亲委派模型确保了 Java 核心库的安全性和一致性。 #### 4. **引用类型** Java 中存在四种不同的引用类型:强引用、软引用、弱引用和虚引用。这些引用类型主要用于管理内存资源并配合垃圾回收器工作[^5]。 #### 5. **Happens-Before 原则** Java 提供了一套 Happens-Before 规则以保障线程间的可见性。其中包括程序顺序规则、监视器锁规则、volatile 变量规则等八大原则[^3]。 #### 6. **循环引用问题** 即使两个对象相互持有对方的引用,在它们不再被任何外部变量引用的情况下,现代垃圾回收器仍然能够识别这种关系并将两者都回收掉[^2]。 ```java // 循环引用示例 class Node { private Node next; public Node(Node n) { this.next = n; } protected void finalize() throws Throwable { System.out.println("Finalizing..."); } } public class CircularReferenceTest { public static void main(String[] args) throws InterruptedException { Node nodeA = new Node(null); Node nodeB = new Node(nodeA); nodeA.next = nodeB; // 创建循环引用 nodeB = null; nodeA = null; System.gc(); Thread.sleep(100); // 等待垃圾回收完成 } } ``` #### 7. **JVM 参数调优** 通过设置 `-Xms` 和 `-Xmx` 来指定初始堆大小和最大堆大小;利用 `-XX:+UseG1GC` 开启 G1 垃圾收集器可以有效提升大型应用程序的表现[^4]。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值