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

本文探讨了Java虚拟机中两种主要的内存管理算法:引用计数算法和可达性分析算法。详细解析了这两种算法的工作原理,以及为什么Java选择了可达性分析算法来判断对象是否可被回收。同时介绍了GCRoots的概念及其包含的各类对象。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

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

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

在这里插入图片描述
蓝色为仍然存活的对象;白色为判定为可回收的对象

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值