总:对堆垃圾回收前的要判断哪些对象已经死亡(即不能再被任
何途径使用的对象)。两种方法:引用计数法和可达性分析算法。
一.引用计数法:给对象中添加一个引用计数器,引用一次,加1;引用失效,计数器减1;计数器为0的对象是不可能再被使用的。
注意:不被主流虚拟机使用,因为要考虑很多情况。比如两个没用的对象相互循环引用,A引用B,B引用A。
二.可达性分析算法:通过一系列的称为 “GC Roots” 的对象作为起点,从这些节点向下搜索, 节点所走过的路径称为引用链,当一个对象到 GC Roots 没有任何引用链相连的话,则证明此对象是不可用的。
1.GC Roots对象包括:
- 虚拟机栈(栈帧中的本地变量表)中引用的对象
- 方法区中类静态属性引用的对象
- 方法区中常量引用的对象
- 本地方法栈中JNI(即一般说的native方法)中引用的对象
- java虚拟机内部的引用,如基本数据类型对应的class对象,异常对象,系统类加载器
- 同步锁(synchronized)持有的对象
- JMXBean,JVMTI中注册的回调,本地代码缓存