JVM

JVM - 判断对象是否存活算法

2018-08-21  本文已影响0人  HRocky

在堆里面存放着Java世界中几乎所有的对象实例,垃圾收集器在堆进行回收前,第一件事情就是要确定这些对象之中哪些还“存活”着,哪些已经“死去”(即不可能再被任何途径使用的对象)。

下面介绍两种算法来判断对象是否存活。

1. 引用计数算法

思想:给对象中添加一个引用计数器,每当有一个地方引用它时,计数器值就加1;当引用失效时,计数器值就减1;任何时刻计数器为0的对象就是不可能再被使用的。

缺点:很难解决对象之间相互循环引用的问题。

主流的Java虚拟机里面没有选用引用计数算法来管理内存。

2. 可达性分析算法

思想:通过一系列的称为“GC Roots”的对象作为起始点,从这些节点开始向下搜索,搜索所走过的路径称为引用链(Reference Chain),当一个对象到GC Roots没有任何引用链相连(用图论的话来说,就是从GC Roots到这个对象不可达)时,则证明此对象是不可用的。

2.1 可作为GC Roots的对象

在Java语言中,可作为GC Roots的对象包括下面几种:

上一篇下一篇

猜你喜欢

热点阅读