Java JVM垃圾回收确定垃圾的两种方式,GC Root

文章目录

前言

对于Java两种确定对象为可回收的两种方式,予以记录!

一、如何确定是垃圾?

内存中已经不再被使用到的空间就是垃圾

  • 引用计数法
  • 根可达路径法

引用计数法

根可达路径法

枚举根节点做可达性分析(根搜索路径)

二、GC Root

1、以下可作为GC Root对象

  1. 虚拟机栈(栈帧中的本地变量表)中引用的对象。
  2. 方法区中(1.8称为元空间)的类静态属性引用的对象,一般指被static修饰的对象,加载类的时候就加载到内存中。
  3. 方法区中的常量引用的对象。
  4. 本地方法栈中的JNI(native方法)引用的对象。

2、判断可回收:GC Root不可达

此对象到GCRoot对象没有引用链,此对象到GCRoot对象再也找不到一条可达路径

在可达性分析法中不可达的对象,它们暂时处于"缓刑阶段",要真正宣告一个对象死亡,至少要经历两次标记过程;

3、真正宣告对象死亡需经过两次标记过程(重要)

可达性分析法中不可达的对象被第一次标记并且进行一次筛选,筛选的条件是此对象是否有必要执行 finalize 方法

当对象没有覆盖 finalize 方法,或 finalize 方法已经被虚拟机调用过时,虚拟机将这两种情况视为没有必要执行。

被判定为需要执行的对象将会被放在一个队列中进行第二次标记,除非这个对象与引用链上的任何一个对象建立关联,否则就会被真的回收。

相关推荐
小bo波6 小时前
使用Thread子类创建线程 VS 使用Runnable接口创建线程的区别
java·多线程·thread·并发编程·runnable
SamDeepThinking7 小时前
高并发场景下,CompletableFuture与ForkJoinPool该如何取舍?
java·后端·面试
张不才9 小时前
CPU 100% 了怎么办?Java 性能排障的标准化操作
java·后端
shepherd11111 小时前
吞吐量提升 10 倍:高并发大批量数据处理任务的架构演进与性能调优
java·后端·架构
plainGeekDev14 小时前
单例模式 → object 声明
android·java·kotlin
用户2986985301414 小时前
Java 实现 Word 文档文本与图片提取的方法
java·后端
SimonKing15 小时前
铁子,IntelliJ IDEA 2026.1.3来了,升不升?
java·后端·程序员
咖啡八杯1 天前
GoF设计模式——策略模式
java·后端·spring·设计模式
用户128526116021 天前
我把祖传Java项目重构后,接口响应从3s砍到了200ms,只改了这几行代码
java