jvm常见的面试题

jre=JVM+Java类库

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

jvm的运行时数据区:

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

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

java的垃圾回收机制:

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

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

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

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

什么是标记清除法:

从根节点出发,访问过的路径进行标记。

清除的时候,清除没有标记的那些。

内存溢出问题:oom

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

什么是内存泄漏:

JVM对象头里面的数据:

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

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

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

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

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

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

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

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

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值