引用计数算法
对象中添加一个引用计数,一个地方引用它时,计数器值就加1,当引用失效时,计数器值就减一
两对象互相引用,就会造成死循环,无法回收
可达性分析算法
通过GC Roots作为起点,向下搜索,到达不了的对象,即证明对象不可用
GC Roots 包括:虚拟机栈中引用的对象、方法区中类静态属性引用的对象、方法区中常量引用的对象、本地方法栈中JNI(Native方法) 引用的对象
细分引用
JDK1.2之后,Java将引用分为:强引用、软引用、弱引用、虚引用
强引用:Object object = new Object() 这类的引用
软引用:有用但并非必需的对象,通过SoftReference类来实现,在系统将要内存溢出时会列进回收范围
弱引用:非必需对象,通过WeakReference类来实现,在下一次垃圾收集时会被回收
虚引用:仅是提供回收时能收到一个通知,通过phantomReference类来实现
回收的具体流程
GC Roots 到达不了的,第一次会被标记和筛选,筛选的条件是次对象是否有必要执行finalize()方法,如果没有该方法或该方法已执行,则虚拟机不执行finalize()方法;
如果有必要执行finalize()方法,虚拟机则会将对象放置到F-Queue队列中,由低优先级的Finalizer线程执行它,进行第二次标记,在第二次标记钱对象与引用链上的任何对象建立关联,它将被移除回收队列,否则就真的被回收了