JVM中判定对象是否回收的的方法

引用计数法

引用计数法是一种垃圾回收(Garbage Collection)算法,用于自动管理内存中的对象。在引用计数法中,每个对象都有一个关联的引用计数器,用于记录对该对象的引用数量。

当一个新的引用指向对象时,该对象的引用计数器加1;当一个引用不再指向对象时,对象的引用计数器减1。当引用计数器的值为0时,说明该对象没有被引用,即可被认定为垃圾对象,可以被垃圾回收器回收内存。

引用计数法的优点是实时性强,一旦没有引用指向对象,就可以立即释放内存。

缺点:

不能解决循环依赖

循环依赖:两个对象相互依赖,这样计数器就不会清零

可达性分析算法

Java 虚拟机中的垃圾回收器采用可达性分析来探索所有存活的对象

可达性分析算法的基本思想是从一组称为"根"的起始对象开始,递归地遍历对象引用链,标记所有被访问到的对象为存活对象,而未被标记的对象则被认定为垃圾对象,可以被垃圾回收器回收内存。

在JVM中,根对象通常包括以下几种:

  1. 本地变量表中引用的对象:包括当前执行的方法中使用的对象引用。
  2. 静态变量中引用的对象:即类的静态字段所引用的对象。
  3. 活动线程中的对象:即正在执行的线程中的对象。
  4. JVM内部的引用:例如常量池中的引用、类静态引用等。

通过从根对象开始,可达性分析算法会遍历对象的引用链,找到所有可达对象。未被访问到的对象则被认定为垃圾对象。

可达性分析算法的优点是能够准确地判断对象是否存活,避免了引用计数法中循环引用的问题。然而,可达性分析算法的缺点是需要进行全局扫描,可能会造成一定的性能开销。

相关推荐
JAVA社区24 分钟前
Java高级全套教程(十一)—— Kubernetes 超详细企业级实战详解
java·运维·微服务·容器·面试·kubernetes
8Qi839 分钟前
LeetCode 23. 合并 K 个升序链表 —— 小顶堆(PriorityQueue)
数据结构·算法·leetcode·链表·
QiLinkOS1 小时前
《打破“用爱发电”:一种基于 Gitee 与时间戳的开源权益分配机制探索》
c语言·数据结构·c++·科技·算法·gitee·开源
松间听晚2 小时前
Agentic RL 环境和代码学习:以HGPO为例
算法
智者知已应修善业2 小时前
【51单片机用T0定时器方式1,实现0.5S的时间间隔实现第一次一个灯亮、第二次二个灯亮,直到全部灯亮,然后重复整个过程】2023-12-29
c++·经验分享·笔记·算法·51单片机
在繁华处2 小时前
Java从零到熟练(九):并发编程基础
java·开发语言
木头程序员2 小时前
SSM框架学习笔记
java·开发语言·mysql·spring·maven
小许同学记录成长2 小时前
几何体编辑与布尔运算
算法·无人机
李白你好2 小时前
页面资产梳理 · 技术指纹识别 · Spring 端点探测
java·后端·spring
一起逃去看海吧2 小时前
dify-03
java·linux·开发语言