jvm判断对象是否存活的算法

参考书籍《深入理解Java虚拟机》周志明

1,引用计数算法
在对象中添加一个引用计数器,每当一个地方引用它时,计数器就加1,引用失效时计数器就减1,任何时刻计数器为0的对象就是不可能再被使用的对象。
在Java主流虚拟机中没有选择这一算法管理内存,原因是引用计数算法有很多例外情况要考虑,必须要配合大量额外处理才能保证正确的工作,单纯的使用引用计数就会很难解决对象之间循环引用的问题。
2,可达性分析算法
当前主流的程序语言的内存管理子系统都是通过可达性分析算法来判定对象的存活与否
基本思路是通过一系列称为GC Roots的根对象作为起始节点集,从这些节点开始,根据引用关系向下搜索,搜索过程所走过的路径称为引用链,如果某个对象到GC Roots间没有任何引用链相连,则证明此对象不可能再被使用。

Object1-4到GC Roots都是可达的,而Object5-6之间虽然可达,但是到GC Roots是不可达的

jvm判断对象是否存活的算法
蓝色为仍然存活的对象;白色为判定为可回收的对象

在Java体系中,固定可作为GC Roots的对象有:

  1. 在虚拟机栈中引用的对象,譬如各个线程被调用的方法堆栈中使用到的参数,局部变量,临时变量等
  2. 在方法区中类静态属性引用的对象,如Java类的引用类型静态变量
  3. 在方法区中常量引用的对象,如字符串常量池里的引用
  4. 在本地方法栈中JNI引用的对象(Native方法)
  5. Java虚拟机内部的引用,如基本数据类型对应的Class对象,一些常驻的异常NPE,OOM等,系统类加载器
  6. 所有被同步锁(Synchronized)持有的对象
  7. 反应Java虚拟机内部情况的JMXBean,JVMTI中注册的回调,本地代码缓存等