前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >面试高峰期,如何应对面试官的jvm刁难,特写一篇jvm面经(第一部)

面试高峰期,如何应对面试官的jvm刁难,特写一篇jvm面经(第一部)

作者头像
用户1257393
发布2018-03-21 17:04:46
1.2K0
发布2018-03-21 17:04:46
举报
文章被收录于专栏:精讲JAVA精讲JAVA精讲JAVA
读者前言

已经进入三月份,正所谓金三银四,正是一年最好的招聘期,想必我的公号粉丝们一定有不少想要跳槽的吧,哈哈,/**偷偷告诉你们其实小编也准备跳槽*/(我要加个注释,被老板知道可就完蛋了),说到面试,想必大家一定气不打一处来,明明拧螺丝的活,非让我们有造火箭的技术,话是这么说,其实很多面试官问jvm题主要原因有两个,一是让你感觉他们公司很牛,二就是压低你的工资,这就是他们的套路,真正能用到的公司少之又少,但是我们还必须了解jvm的,在此,话不多少,小编整合多年jvm的经验,外加星球的朋友提出的面试遇到的问题,整理一篇jvm面经,希望大家喜欢吧。

Q:jvm中一次完整的GC流程

首先对象会在新生代分配,如果新生代没有资源了,就会进行新生代回收,即Minor GC(后面简称MG),如果MG后对象依然存活,将会给对象年龄+1,重复整个操作,如果年纪达到了年龄阈值,就会将对象存入老年代,这里还有一个特殊的地方,如果你的对象是一个需要大量连续的内存空间的对象,则直接会进入老年代

Q:一共有几种常用垃圾回收机制,各自优缺点,如何启用

1、串行收集器:暂停所有的线程,属于单线程工作,

启用:-XX:+UseSerialGC

2、并行收集器(默认):暂停所有线程,多线程工作

启用:-XX:+UseParNewGC

3、G1收集器:这个主要是对堆内存进行分区,并发性回收

启用:-XX:+UseG1GC

4、CMS收集器:多线程扫描,使用的算法是标记清除算法,标记需要回收的对象,进行回收

启动:-XX:+UseConcMarkSweepGC

Q:新生区跟养老区默认按照多大比例分配的?

首先新生代跟老年代没有明确多少,大家基本上都是1:2,这个都是可以配置的,

Q:伊甸园区、幸存0区,幸存1区默认分配比例

新生代中的eden跟survivor的默认比例是8:1:1

Q:什么叫做指令重排序,内存栅栏

内存栅栏是一个同步屏蔽指令,是CPU对内存访问时的同步标记,可以让前面的都执行完成后,在执行栅栏后面的东西,你可能会问,所有的程序执行不是一步一步运行的吗,为什么还要控制,其实现在机器上为了提高性能,都采用了乱序执行,你先定义一个变量A在定义一个变量B,理论上是先执行A在执行B,但是有可能是先执行的B,在执行A,所以,这就是乱序执行,而栅栏就是这么出现的,保证程序执行不乱序,当然不能保证每一句话都不乱序,只能保证这个节点前后的执行不要相互混乱了,内存可见性的底层原理就是内存栅栏

Q:g1和cms区别,吞吐量优先和响应优先的垃圾收集器选择

CMS收集器:是基于标记清除算法实现的,一般就是初始标记,并发标记,重新标记,并发清除,目的是实现最短的响应回收时间。保证系统的响应时间,减少垃圾收集时的停顿时间

G1收集器:他的过程是初始标记、并发标记、最终标记、筛选回收,基于标记整理算法实现,以吞吐量优先,保证保证吞吐量的。

Q:强引用、软引用、弱引用、虚引用

强引用:new出的对象之类的引用, 只要强引用还在,永远不会回收 软引用:引用但非必须的对象,内存溢出异常之前,回收 弱引用:非必须的对象,对象能生存到下一次垃圾收集发生之前。 虚引用:对生存时间无影响,在垃圾回收时得到通知。

Q:volatile如何保证可见性

使用volatile修饰时,可以理解成所有的操作都放到了主存中,,多个线程共享数据时,可以保证内存中的数据可见,一个线程修改了数据,会立即更新到主存,下一个线程使用时一定是最新的数据,这便是可见性

Q:jvm内存是怎么分配的

在Jvm中,Java少了很多权力,比如说配置和释放资源,因为这一切都交给jvm来完成,所以这种情况下我们Java程序员比C程序员轻松很多,不容易造成内存溢出,但是引发一个新的问题,就是一旦出现溢出问题,我们不了解jvm就会没办法解决问题,所以学习jvm的原因就在这,

我来解释一下这个问题啊

jvm内存分配一共有这几个地方,

程序计数器:占用内存较小,就是为字节码做行号引用的

Java虚拟机栈:其实可以理解为我们经常听到的栈内存,

本地方法栈:就是为虚拟机使用的Native方法所用,

Java堆:这是jvm中用到最多的地方,所有的线程都可以使用,用来放实例

方法区:也是被所有的线程共同使用的,用来存储静态变量,常量等

Q:新生代,老年代,永生代的含义与区别

hotspot把新生代分为1个Eden区和2个Survivor区(分别叫from和to)。默认比例为8:1,一般情况下,新创建的对象都会被分配到Eden区,如果Minor GC一次后还存在,将会加入Survivor,每次对象坚持在Minor GC存活一次,这个对象就会计数+1,当达到某个数值(年龄阈值,可以通过-XX:MaxTenuringThreshold来设置)后,就会转移到老年代,新生代的算法是复制算法,关于什么叫复制算法,可以百度,在新生代开始GC时,所有的对象都存在于Eden跟from中,当GC完成后,Eden中还存在的对象会进入to,在from中的对象,根据计数的个数取决去哪,没达到阈值的进入to,达到的进入老年代,所以每次进行GC后,from跟Eden都是空,第二次GC时,上一次的to就变成这一次的from,(不知道我这么说能不能明白)因为没有进入老年代,第二次Minor GC还会对from,也就是这一次的from中的对象进行回收,反复重复该过程。

什么叫做老年代呢,老年代都是从新生代熬过来的对象,就是达到年龄阈值的对象,所以老年代不会那么频繁的进行回收了,老年代的回收称为Major GC 就是清理老年代,老年代回收频率低于新生代。

什么叫做永久代呢,其实永久代在hotspot中就是方法区,存放常量池等东西地方。以后可能会取代,

结束语

先写这些吧,写多了,大家没兴趣看了,我们的口号就是“怼死面试官,从我做起”,大家一定要记住暗号

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-03-06,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 精讲JAVA 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档