已经进入三月份,正所谓金三银四,正是一年最好的招聘期,想必我的公号粉丝们一定有不少想要跳槽的吧,哈哈,/**偷偷告诉你们其实小编也准备跳槽*/(我要加个注释,被老板知道可就完蛋了),说到面试,想必大家一定气不打一处来,明明拧螺丝的活,非让我们有造火箭的技术,话是这么说,其实很多面试官问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中就是方法区,存放常量池等东西地方。以后可能会取代,
结束语
先写这些吧,写多了,大家没兴趣看了,我们的口号就是“怼死面试官,从我做起”,大家一定要记住暗号