JVM-可达性分析算法

JVM-可达性分析算法

内容参考 《深入理解Java虚拟机》第三版

 

当前主流的商用程序语言(Java、C#)的内存管理子系统,都是通过 可达性分析(Reachability Analysis) 算法来判定对象是否存活的。

这个算法得基本思路就是通过一系列称为 "GC Roots" 的跟对象作为起始节点集,根据引用关系乡下搜索,搜索过程所走过的路径成为 “引用链”(Reference Chain),如果某个对象到 GC Roots 间没有任何引用链相连,或者用图论的话来说就是从 GC Roots 到这个对象不可达,则证明此对象是不可能再被使用的。

Object 5、6、7 因为不可达,在这里就可以进行回收

在 Java技术体系里,固定可作为 GC  Roots 的对象包括以下几种

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

 

除了这些固定的 GC Roots 集合之外,根据用户所选用的垃圾收集器以及当前回收的内存区域不同,还可以有其他对象“临时性”地加入,共同构成完整GC Roots 集合。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值