目前是两种方式:
方式一:引用计数器:为每个对象创建一个引用计数,当有对象引用时,计数器+1,
当引用释放时,计数器-1,所以,当计数器为0时,就认为可以被回收。
但这种算法,存在一个问题,存在循环引用的问题。
来,看代码,但一般是为
1 | public static void main(String[] args){ |
方式二:可达性分析
从GC Roots开始向下搜索,搜索所走过的路径称为引用链。
当一个对象到GC Roots没有任何引用链时,则认为此对象可以被回收。
大家可以认为就是一个树的根节点开始计算引用情况。