什么是垃圾
简单来说,就是内存中已经不再被使用到的空间就是垃圾
要进行垃圾回收,要先判断对象是否可以被回收
下面介绍几种用来判断是否垃圾的算法
一、引用计数法(了解即可)
通过给对象添加计数器,每当有一个地方引用它,计数器值就 + 1,有一个地方引用失效就,计数器值就 - 1
只要计数器值为零,就说明这个对象不再被使用,可以当作垃圾回收
优点是 :实现简单
缺点 : 1、每次对对对象的赋值是都要维护引用计数器,且计数器本身也有一定的损耗
2、解决不掉循环引用的问题
二、枚举根节点做可达性分析 (根搜索路径)
基本思路就是通过一系列名为”GC Roots“的对象作为起始点,向下搜索,如果一个对象到GC Roots没有任何引用链相连时,则说明此对象不可用
Java中可作为GC Root的对象
1、虚拟机栈(栈帧中的局部变量表)中引用的对象
public void stack(){
/**
* 栈中局部变量表引用的对象
*/
Object gcRoots = new Object();
}
2、方法区中静态属性引用的对象
public class GCRoots {
private static Object object;
public static void staticDemo(){
/**
* 静态属性引用的对象
*/
object = new Object();
}
3、方法区中常量所引用的对象
private static final Object finalObject;
static {
/**
* 常量引用的对象
*/
finalObject = new Object();
}
4、本地方法栈JNI (native方法)引用的对象
可达性分析 就是从这些结点的集合(GC Root Set)开始遍历,判断对象是否可达,不可达就回收