1.jvm中一次完整的GC流程? 首先对象会在新生代分配,若是新生代没有资源了,就会进行新生代回收,即Minor GC(后面简称MG),若是MG后对象依然存活,将会给对象年龄+1,重复整个操做,若是年龄达到了年龄阀值,就会将对象存入老年代,这里还有一个特殊的地方,若是你的对象是一个须要大量连续的内存空间的对象,则直接进入老年代。程序员
2.一共有几种经常使用垃圾回收机制,各自优缺点,如何启用?算法
3.新生区跟养老区默认按照多大比例分配?多线程
首先新生代跟老年代没有明确多少,你们基本上都是1:2,这个都是能够配置的并发
4.伊甸园区、幸存0区、幸存1区默认分配比例?jvm
新生代中的eden跟survivor的默认比例是8:1:1性能
5.什么叫指令重排序,内存栅栏?学习
内存栅栏是一个同步屏蔽指令,是CPU对内存访问时的同步标记,可让前面的都执行完成后,在执行栅栏后面的东西,你可能会问,全部的程序执行不是一步一步的运行吗?为何还要控制,其实如今机器为了提升性能,都采用乱序执行,你定义一个变量A在定义一个变量B,理论上是先执行A在执行B,可是有多是先执行B在执行A,因此这就是乱序执行,而栅栏就是这么出现的,保证程序执行不乱序,固然不能保证每一句话都不乱序,只是能保证这个节点先后的执行不要互相混乱了,内存可见性的底层原理就是内存栅栏。线程
6.g1和cms区别,吞吐量优先和响应优先的垃圾回收器选择?对象
CMS收集器:是基于标记清除算法实现的,通常就是初始标记,并发标记,从新标记,并发清除,目的是实现最短的响应回收时间。保证系统的响应时间,减小垃圾收集时的停顿时间排序
G1收集器:他的过程是初始标记、并发标记、最终标记、筛选回收,基于标记整理算法实现,以吞吐量优先,保证保证吞吐量的。
7.强引用、软引用、弱引用、虚引用
强引用:new出来的对象之类的引用,只要强引用还在,永远不会回收。 软引用:引用但非必须的对象,内存溢出异常以前,回收。 弱引用:非必须的对象,对象能生存到下一次垃圾收集发生以前。 虚引用:对生存时间无影响,在垃圾回收时获得通知。
8.volatile如何保证可见性?
使用volatile修饰时,能够理解成全部的操做都放到了主存中,多个线程共享资源时,能够保证内存中的数据可见,一个线程修改了数据,会当即更新到主存,下一个线程使用时必定会是最新的数据,这即是可见性。
9.JVM内存是怎么分配的?
在Jvm中,Java少了不少权力,好比说配置和释放资源,由于这一切都交给jvm来完成,因此这种状况下咱们Java程序员比C程序员轻松不少,不容易形成内存溢出,可是引起一个新的问题,就是一旦出现溢出问题,咱们不了解jvm就会没办法解决问题,因此学习jvm的缘由就在这,
我来解释一下这个问题啊
jvm内存分配一共有这几个地方,
程序计数器:占用内存较小,就是为字节码作行号引用的
Java虚拟机栈:其实能够理解为咱们常常听到的栈内存,
本地方法栈:就是为虚拟机使用的Native方法所用,
Java堆:这是jvm中用到最多的地方,全部的线程均可以使用,用来放实例
方法区:也是被全部的线程共同使用的,用来存储静态变量,常量等
10.新生代,老年代,永生代的含义与区别?
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中就是方法区,存放常量池等东西地方。之后可能会取代