欢迎您访问365答案网,请分享给你的朋友!
生活常识 学习资料

jvm常见的面试题

时间:2023-06-09

jre=JVM+Java类库

jdk=jre+Java运行开发调试工具

jvm的运行时数据区:

线程共享的部分:方法区,堆内存,运行时常量池(开启多个线程以后,共享的部分)

线程私有区:本地方法区,虚拟机内存,程序计数器。

java的垃圾回收机制:

该算法的提出是为了克服句柄的开销和解决堆碎片的垃圾回收。它将内存按容量分为大小相等的两块,每次只使用其中的一块(对象面),当这一块的内存用完了,就将还存活着的对象复制到另外一块内存上面(空闲面),然后再把已使用过的内存空间一次清理掉。

      复制算法比较适合于新生代(短生存期的对象),在老年代(长生存期的对象)中,对象存活率比较高,如果执行较多的复制操作,效率将会变低,所以老年代一般会选用其他算法,如标记—整理算法。一种典型的基于Coping算法的垃圾回收是stop-and-copy算法,它将堆分成对象区和空闲区,在对象区与空闲区的切换过程中,程序暂停执行。

      优点:(1)标记阶段和复制阶段可以同时进行。(2)每次只对一块内存进行回收,运行高效。(3)只需移动栈顶指针,按顺序分配内存即可,实现简单。(4)内存回收时不用考虑内存碎片的出现(得活动对象所占的内存空间之间没有空闲间隔)。

      缺点:需要一块能容纳下所有存活对象的额外的内存空间。因此,可一次性分配的最大内存缩小了一半。

内存溢出问题:oom

 

内存泄漏和内存溢出的关系:

什么是内存泄漏:

JVM对象头里面的数据:

运行时数据:重点:mark word  运行时数据。

类型指针:指向创建该对象的类

如果为对象数组,会有一个记录数组长度的数据          

 jvm的垃圾回收器:默认的是并行收集器

原因是:多线程的,考虑吞吐的话也是最优的

简单介绍一下并行垃圾收集的作用:

目的是:缩短垃圾回收的时间

方式:利用cpu的多核,开启多个线程,多个GC worker来进行多线程的操作。

 

 

 

 

Copyright © 2016-2020 www.365daan.com All Rights Reserved. 365答案网 版权所有 备案号:

部分内容来自互联网,版权归原作者所有,如有冒犯请联系我们,我们将在三个工作时内妥善处理。