JVM常见的几个面试题

这块内容并非每个面试官都会问,但是如果是应聘高P的话,这一环节是不可缺少的,面试的难易程度也不一样,有些面试官或许让你讲讲虚拟机的内存实现即可,有些也会让你解释垃圾回收的实现,当然也会有虚拟机调优的实战经验,线上问题排查等等。

当然了,每次看到简历上如果有提到JVM,不管是了解还是精通,我都会尝试问几个问题,从最简单的开始。

问题1

JVM的内存相关,如何实现?

Java堆,Java栈,程序计数器,方法区,1.7的永久代,1.8的metaspace....尽可能多说,顺带简短描述下每个内存区的用途,能想到的都讲出来。

问题2

那么Java的堆内存,如何细分?

很多同学回答这个问题的时候,上来就是啪啦啪啦说一通,当我问他你说的是哪种回收算法时,他愣住了,以为所有算法的内存实现都一样。

比如CMS、G1、ZGC的堆内存实现都不太一样,但是可以说出CMS算法的堆内存实现,已经可以过关了,但是如果能够继续说明下G1和ZGC的实现,那当然是加分项。

问题3

在cms算法中,young gc的实现过程?

先找出根对象,如Java栈中引用的对象、静态变量引用的对象和系统词典中引用的对象等待,把这些对象标记成活跃对象,并复制到to区,接着遍历这些活跃对象中引用的对象并标记,找出老年代对象在eden区有引用关系的对象并标记,最后把这些标记的对象复制到to,在复制过程还要判断活跃对象的gc年龄是否已经达到阈值,如果已经达到阈值,就直接晋升到老年代,YGC结束之后把from和to的引用互换。

其实这里又会遇到几个概念,最好的情况是,面试者可以自己说出来,比如:

  • promotion failed
  • concurrent mode failed

并说明什么情况下会发生,可以如何避免?

问题4

cms算法的几个过程中,哪几个是需要stw的?

这几个过程,为什么需要stw?

问题5

JVM GC问题排查以及性能调优经验

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • JVM架构 当一个程序启动之前,它的class会被类装载器装入方法区(Permanent区),执行引擎读取方法区的...
    cocohaifang阅读 1,713评论 0 7
  • 垃圾回收算法具体实现 翻译原文 => plumbr Java GC handbook 前文参见: Java垃圾回收...
    foxracle阅读 2,892评论 0 15
  • 介绍JVM中7个区域,然后把每个区域可能造成内存的溢出的情况说明 程序计数器:看做当前线程所执行的字节码行号指示器...
    jemmm阅读 2,265评论 0 9
  • 这篇文章是我之前翻阅了不少的书籍以及从网络上收集的一些资料的整理,因此不免有一些不准确的地方,同时不同JDK版本的...
    高广超阅读 15,764评论 3 83
  • 原文阅读 前言 这段时间懈怠了,罪过! 最近看到有同事也开始用上了微信公众号写博客了,挺好的~给他们点赞,这博客我...
    码农戏码阅读 6,039评论 2 31