- 引用计数法:每个对象有一个引用计数属性,新增一个引用时计数器+1,引用释放时计算器 -1,计数为0时可以回收。
- 可达性分析:从GC Roots开始向下收索,搜索走过的路径成为引用链。当一个对象到GC Roots没有任何引用链相连时,则证明此对象是不可用的,那么虚拟机就判断是可回收对象。
引用计数法,可能出现A引用了B,B引用了A,这时候就算他们都不再使用了,但因为相互引用计数器,永远都不会回收。
GC Roots的对象有
- 虚拟机栈(栈帧中的本地变量表)中引用的对象
- 方法区中类静态属性引用的对象。
- 方法区中常量引用的对象。譬如字符串常量池里的引用
- 本地方法栈中引用的对象
- 所有被同步锁持有的对象
- 分代收集时,将其他代的引用对象临时性加入GC Roots
可达性分析算法中的不可达对象并不是立即死亡的,对象拥有一次自我拯救的机会。对象被系统宣告死亡至少要经历两次标记过程:第一次时经过可达性分析发现没有与GC Roots相连接的引用链,第二次是在由虚拟机自动建立的Finalizer队列中判断是否需要执行finalize()方法。
当对象变成GC Roots不可达时,GC会判断该对象是否覆盖了finalize方法,若未覆盖,则直接回收。否则,若对象未执行过finalize方法,将其放入F-Queue队列,由一低优先级线程执行该队列中对象的finalize方法。执行finalize方法后,GC会再次判断该对象是否可达,若不可达则进行回收,可达则复活对象。
每个对象的finalize方法只能被执行一次