jvm基础面试题2024(简介版)

同系列面试题推荐——你的点赞、分享、收藏是对我们最大支持!!!

 JAVA 基础面试题2024(简洁版)-CSDN博客

javaWab面试题(2024简洁版)-CSDN博客

jdk,jre,jvm的区别与联系

  • jdk是java开发工具里面包含了JRE和javac等工具;
  • JRE里面有jvm虚拟机和一些核心类库;
  • jvm是虚拟机,java程序真正运行的地方

1、字节码的作用

java虚拟机统一了文件存储格式,那就是字节码,所有的操作系统平台的JVM都使用这种统一的格式。JVM不强调你使用哪种语言编写程序,只要最后的程序能够翻译成JVM能够识别、加载、并运行的字节码格式即可,所以JVM能够做到跨平台和语言无关性 。

2、jvm整体结构

3、类加载子系统(类加载的过程)、作用(重点)

系统加载 Class 类型的文件主要三步:加载->连接->初始化。连接过程又可分为三步:验证->准备->解析

加载

  1. 通过全类名获取定义此类的二进制字节流。

  2. 将字节流所代表的静态存储结构转换为方法区的运行时数据结构。

  3. 在内存中生成一个代表该类的 Class 对象,作为方法区这些数据的访问入口。

连接:

验证加载的class文件是否正确;

为类变量分配内存并设置类变量初始值;

将常量池内的符号引用替换为直接引用的过程;(类名指向真正的地址)

初始化:

执行初始化方法 方法的过程,是类加载的最后一步,这一步 JVM 才开始真正执行类中定义的 Java 程序代码

类加载器的主要作用就是加载 Java 类的字节码到 JVM 中,在内存中生成一个代表该类的 Class 对象

4、jvm内置的3种类加载器(重点)

  • 启动类加载器;
  • 扩展类加载器;
  • 应⽤类加载器 ;

5、什么是双亲委派机制(重点)

双亲委派机制是指⼀个类在收到类加载请求后,首先会检查是否已经被加载,如果没有的话,不会尝试⾃⼰加载这个类,⽽把该类加载请求委派给其⽗类去完成,⽗类在接收到该加载请求后,又会继续检查是否已经被加载,没有被加载就继续将其委派给⾃⼰的⽗类,以此类推,这样所有的类加载请求都被向上委派到启动类加载器中。若⽗类加载器在接收到类加载请求后发现⾃⼰也⽆法加载该类,则⽗类会将该请求向下委派到⼦类加载器加载该类,直到被加载成功,若找不到会曝出异常 。

6、如何打破双亲委派机制?

创建⼀个类继承ClassLoader,并重写loadClass⽅法。

7、运行时数据区域(重点)

线程共享的:

  • 方法区

  • 直接内存 (非运行时数据区的一部分)

线程私有的:

  • 程序计数器(不会发生内存溢出)

  • 虚拟机栈

  • 本地方法栈

(1)程序计数器:

保存下⼀条需要执⾏的字节码指令,是程序控制流的指⽰器,分⽀、循环、跳 转、异常处理、线程恢复等基础功能都是依赖程序计数器。 ( 程序计数器是唯一一个不会出现 OutOfMemoryError (内存溢出)的内存区域,它的生命周期随着线程的创建而创建,随着线程的结束而死亡。 )

(2)Java 虚拟机栈

(⽣命周期与线程相同)Java中每个⽅法执⾏的时候,Java虚拟机都会同步创建 ⼀个栈帧,⽤于存储局部变量表、操作数栈、动态链接、⽅法出口等信息。

(3)本地方法栈

和虚拟机栈所发挥的作用非常相似,区别是:虚拟机栈为虚拟机执行 Java 方法 (也就是字节码)服务,而本地方法栈则为虚拟机使用到的 Native 方法服务。

(4)堆

Java 虚拟机所管理的内存中最大的一块,Java 堆是所有线程共享的一块内存区域,在虚拟机启动时创建。此内存区域的唯一目的就是存放对象实例,几乎所有的对象实例以及数组都在这里分配内存。

(5)方法区

方法区属于是 JVM 运行时数据区域的一块逻辑区域,是各个线程共享的内存区域。

⽤来存储已经被虚拟机加载的类型信息、常量、静态变量、即是编译器编译后的代码缓存等数据。

运行时常量池

存放编译期生成的各种字面量和符号引用的 常量池表

8、GC(垃圾回收)区域

伊甸区:s0:s1 = 8:1:1

部分收集 (Partial GC):

  • 新生代收集(Minor GC / Young GC):只对新生代进行垃圾收集;

  • 老年代收集(Major GC / Old GC):只对老年代进行垃圾收集。目前只有CMS垃圾收集器会单独对老年代进行垃圾收集,其他垃圾器基本上都是整堆回收的时候才对老年代进行垃圾收集;

  • 混合收集(Mixed GC):对整个新生代和部分老年代进行垃圾收集。

9、为什么要进行垃圾回收?

垃圾是指JVM中没有任何指向它的对象,不及时清理,它们就会一直占用内存,而不能给其他对象进行使用,最终垃圾对象越来越多,就会导致OOM。(内存溢出)

10、死亡对象判断方法(垃圾标记阶段)(重点)

(1) 引用计数法

给对象中添加一个引用计数器:

每当有一个地方引用它,计数器就加 1;

当引用失效,计数器就减 1;

任何时候计数器为 0 的对象就是不可能再被使用的。

这个方法实现简单,效率高,但是目前主流的虚拟机中并没有选择这个算法来管理内存,其最主要的原因是它很难解决对象之间循环引用的问题。(两个对象相互引用)

(2) 可达性分析法

这个算法的基本思想就是通过一系列的称为“GC Roots”的对象作为起点,从这些节点开始向下搜索,节点所走过的路径称为引用链,当一个对象到GC Roots 没有任何引用链相连的话,则证明此对象是不可用的,需要被回收。

哪些对象可以作为 GC Roots 呢?

  • 虚拟机栈(栈帧中的局部变量表)中引用的对象

  • 本地方法栈(Native 方法)中引用的对象

  • 方法区中类静态属性引用的对象

    • 方法区中常量引用的对象

  • 所有被同步锁持有的对象

  • JNI(Java Native Interface)引用的对象

11、被标记为GC的对象⼀定会被GC掉吗?

参考答案:不⼀定,还有逃脱的可能。真正宣告⼀个对象死亡⾄少经历两次标记的过程。 如果对象进⾏可达性分析后没有与GC Roots相连,那么这是第⼀次标记,之后会在进⾏⼀次 筛选,筛选的条件是 是否有必要执⾏finalize()⽅法。

12、垃圾收集算法有哪些(重点)

(1)标记清除:算法分为“标记”和“清除”两个阶段:⾸先标记出不需要需要回收的对象,在标记完成后统⼀回收未被标记的对象。(效率不高、容易产生大量内存碎片)

(2)标记复制:将内存分为大小相同的两块,每次使用其中的一块。把A块中的可达对象复制到B块,然后把使A块内存一次性清除。这样就使每次的内存回收都是对内存区间的一半进行回收。(可用内存变小,对象数量太大会复制很多,导致性能低)

(3) 标记整理:⾸先标记出所有需要回收的对象,在标记完成后,让所有存活的对象都向⼀端移动,然后直接清理边界以外所有的空间。

13 、新⽣代和⽼年代⼀般使⽤什么算法?

新生代采用标记-复制算法,老年代采用标记-整理算法。

14、分代收集算法

一般将 Java 堆分为新生代和老年代,这样我们就可以根据各个年代的特点选择合适的垃圾收集算法。

在新⽣代中,每次垃圾收集时都发现有⼤批对象死去,只有少量存活,那就选⽤复制算法,只需要付出少量存活对象的复制成本就可以完成收集。⽽⽼年代中因为对象存活率⾼、没有额外空间对它进⾏分配担保,就必须使⽤“标记—清理”或者“标记—整理”算法来 进⾏回收。

15、垃圾回收器有哪些?(重点)

在新⽣代有Serial、ParNew、Parallel Scavenge GC;⽼年代有Serial Old、Parallel Old、CMS;

还有不分区的G1算法。

16、现在jdk默认使⽤的是哪种垃圾回收器?

jdk1.8 默认垃圾收集器Parallel Scavenge(新⽣代)+Parallel Old(⽼年代)

jdk1.9 默认垃圾收集器G1

17、CMS垃圾回收器的过程是什么样的?会带来什么问题?

(1)初试标记: 暂停所有的其他线程,并记录下直接与 root 相连的对象,速度很快 ;

(2)并发标记: GC 和⽤户线程⼀起⼯作,执⾏GC Roots跟踪标记过程,不需要暂停⼯作线程。

(3)重新标记:在并发标记过程中⽤户线程继续运作,导致在垃圾回收过程中部分对象的状 态发⽣了变化,未来确保这部分对象的状态的正确性,需要对其重新标记并暂停⼯作线程。

(4)并发清除:清理标记阶段判断的已经死亡的对象,这个过程⽤户线程和垃圾回收线程同时发⽣

问题

  • 对 CPU 资源敏感;

  • 无法处理浮动垃圾;

  • 它使用的回收算法-“标记-清除”算法会导致收集结束时会有大量空间碎片产生。

18、G1垃圾回收器的改进是什么

G1垃圾回收器抛弃了分代的概念,将堆内存划分为⼤⼩固定的⼏个独⽴区域,并 维护⼀个优先级列表,在垃圾回收过程中根据系统允许的最长垃圾回收时间,优先回收垃圾 最多的区域。

G1突出的地⽅: 基于标记整理算法,不产⽣垃圾碎⽚。

可以精确的控制停顿时间,在不牺牲吞吐量的前提下实现短停顿垃圾回收

19、jvm调优了解过吗?常⽤的命令和⼯具有哪些?

jvm性能指标:

堆内存使用率 垃圾回收时间 线程数 CPU使用率 响应时间。

Linux中有top、vmstat、pidstat等命令,jdk中的jstat、jps、jmap、jstack等。


感谢您的浏览!!!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

南巷旧人173

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值