可达性分析算法

内容概述

当前主流的商用JVM都采用可达性分析算法来判断对象是否存活。这个算法的基本思路就是通过一系列称为"GC Roots"的根对象作为起始点,从这些节点开始根据引用关系向下搜索,搜索过程所走过的路径称为引用链,当一个对象到任何GC Roots都没有引用链相连时,则证明此对象是不可用的,可以被回收。

可达性分析算法将 Java 堆视为一个有向图 。它不再纠结于单纯的引用计数,而是通过一组被称为 GC Roots 的节点(如栈中引用的对象、静态属性)作为起点,进行深度优先搜索

搜索过程中走过的路径即为"引用链"。如果一个对象无法通过任何路径连接到 GC Roots,哪怕它持有循环引用,也会被判定为"垃圾"。这是 G1、CMS 等现代收集器的核心逻辑。

思考一下

问题: 如果 GC Roots 集合被错误地清空,会发生什么?

提示: 考虑整个堆内存中的对象是否会被瞬间全部回收,包括正在使用的核心对象。

相关推荐
搜佛说21 小时前
比SQLite更快,比InfluxDB更轻:sfsDb的降维打击
jvm·数据库·物联网·架构·sqlite·边缘计算·iot
阿捞21 天前
JVM排查工具单
java·jvm·python
一定要AK1 天前
JVM 全体系深度解析笔记
java·jvm·笔记
Lyyaoo.1 天前
【JAVA基础面经】== 和 equals() 的区别
java·开发语言·jvm
wuxinyan1231 天前
Java面试题46:一文深入了解JVM 核心知识体系
java·jvm·面试题
周末也要写八哥2 天前
多进程和多线程的特点和区别
java·开发语言·jvm
Engineer邓祥浩2 天前
JVM学习笔记(6) 第二部分 自动内存管理 第5章节 调优案例分析与实战
jvm·笔记·学习
墨神谕2 天前
解释执行与JIT
jvm
滑德友2 天前
jvm的metaSpace内存溢出问题排查
jvm
sinat_255487812 天前
泛型:类·学习笔记
java·jvm·笔记·学习