一、如何判断一个对象是否存活?
没有被任何对象所引用,两种方式:引用计数算法和可达性分析算法
(1)引用计数算法:
每个对象实例都有一个引用计数器,被引用+1,完成引用-1;存在虚拟机上的,任何引用对象为0 的实例可以被当做垃圾来回收的。
优点:执行效率高,程序执行受影响小。
确定:无法检测出循环引用的情况。
(2)可达性分析算法
判断对象的引用链是否可达,决定对象是否是否被回收
GC根开始遍历,可达的被标记存活。
二、可作为GC Roots的对象有哪些?
虚拟机栈中引用的对象
方法区中常量引用的对象
方法区中类静态属性引用的对象
本地方法中JNI(Native方法)的引用对象
活跃的线程的引用对象
三、垃圾回收算法有哪些?
(1)标记清除算法:从根集合进行扫描,不可达的对象进行清楚。
缺点:碎片化,不连续的内存碎片。后续较大的内存时候,无法分配。
(2)复制算法:
分为对象面和空闲面,对象在对象面上创建,存活的对象被从对象面复制到空闲面,将对象面所有的对象内存清除
优点:解决碎片化问题,顺序分配内存,简单高效
(3)标记整理算法
标记清除算法基础上,进行对象移动。
避免了内存不连续性,不用设置两块内存互换适用于存活率高的场景
(4)分代收集算法
垃圾回收算法的组合拳,按照不同对象生命周期的不同区域进行回收。
四、GC是什么?为什么要GC?
Generational Collector,分代收集算法
垃圾回收算法的组合拳,按照不同对象生命周期的不同区域进行回收。
目的:提供JVM垃圾回收效率
五、Minor GC 和 Full GC的区别?
Minor GC :新生代
年轻代:
Eden区
两个Surcivor区
六、对象如何晋升到老年代?
经历一定的Monor GC次数,依然存活的对象。一般15次
Survivor区中存放不下的对象
新生成的大对象
七、常用的调优参数?
老年代:标记清理算法和标记整理算法
八、Full GC 的触发条件?
(1)老年代空间不足
(2)JDC 7以下,永久代空间不足
(3)Monir GC晋升到老年代的平均大小 大于老年代的剩余空间
(4)程序调用了System.gc();
九、JVM 的运行模式:
Server 和Client模式
十、有哪些垃圾回收器?
十一、强引用、软引用、弱引用、虚引用是什么,有什么区别?
String str=new String(original:"abc");//强引用
SoftReference<String> softRef=new SoftReference<String>(str);//软引用
(1)强引用:
抛出内存溢出终止程序也不会回收具有强引用的对象
通过将对象设置为null来弱化引用,使其被回收。
(2)软引用:
对象处在有用但非必须的状态
只有将内存不足时候,GC会回收
可以用来实现高速缓存
(3)弱引用:
非必须的对象,比软引用更弱一些。GC时会被回收,被回收的概率也不大,因为GC线程优先级比较低,适用于引用偶尔被使用且不影响垃圾收集的对象。
(4)虚引用:
不会决定对象的生命周期,任何时候都可能被垃圾回收器回收。跟踪对象被垃圾收集器回收的活动,起哨兵的作用。必须和引用队列referenceQueue联合使用