【基础篇】十二、引用计数法 可达性分析算法

文章目录

  • 1、Garbage Collection
  • 2、方法区的回收
  • 3、堆对象回收
  • 4、引用计数法
  • 5、可达性分析算法
  • 6、查看GC Root对象

在这里插入图片描述

1、Garbage Collection

C/C++,无自动回收机制,对象不用时需要手动释放,否则积累导致内存泄漏:

在这里插入图片描述
Java、C#、Python、Go等支持对不再使用的对象进行回收:

在这里插入图片描述

Java引入GC机制,主要负责对上的内存进行回收,简化了对象的释放,但同时也丧失了回收的及时性,因为回收操作不再又开发者做了。

在这里插入图片描述

线程不共享的部分,随着线程的创建而创建,随着线程的死亡而销毁,不会发生内存泄漏。且栈里的每个栈帧,在方法执行完后直接弹栈并释放内存,都不用等到线程死亡。

在这里插入图片描述
添加JVM参数:

-verbose:gc

可查看回收日志

2、方法区的回收

即回收不再使用的类,对应类生命周期里的卸载阶段。类A被卸载,需同时满足

  • 类的所有实例对象全被回收,堆中再无它的对象或子类的对象
  • 加载类A的类加载器被回收
  • 类A的java.lang.Class对象没有任何地方在引用
URLClassLoader loader = new URLClassLoader(new URL[] {new URL("file:D:\\lib\\")});
Class<?> clazz = loader.loadClass("com.plat.domain.A");
Object a = clazz.newInstance();
a = null;
clazz = null;
loader = null;

Demo代码如下,循环体中创建的变量,一轮结束后自动没用,不用重复 o = null

public class Demo2 {public static void main(String[] args) {try {ArrayList<Class<?>> classes = new ArrayList<>();ArrayList<ClassLoader> loaders = new ArrayList<>();ArrayList<Object> objs = new ArrayList<>();while (true) {//URLClassLoader classLoader = new URLClassLoader(new URL[]{new URL("file:D:\\tmp\\")});BreakClassLoader1 classLoader = new BreakClassLoader1();  //自定义类加载器classLoader.setBasePath("D:\\springboot\\jvm\\target\\classes\\");Class<?> clazz = classLoader.loadClass("com.plat.app.Demo1");Object o = clazz.newInstance();//循环体中创建的变量,一轮结束后自动没用,不用重复 o = null 、clazz = null 、classLoader = null/*打开这里的任意一句,就有一个对应的对象被引用,类卸载就会失败objs.add(o);loaders.add(classLoader);classes.add(clazz);*///手动触发一次垃圾回收,但不是立即//是对JVM的请求,具体是否回收JVM自行决断System.gc();}} catch (Exception e) {e.printStackTrace();}}}public class Demo1  {static{System.out.println("类A被加载");}
}

添加JVM参数:

//运行过程中打印类的加载信息
-XX:+TraceClassLoading   //类被卸载的时候打印一句日志
-XX:+TraceClassUnloading  

运行:

在这里插入图片描述

但其实类的卸载不常见,因为自定义类的累加载器对象还在,热部署中用的多:

在这里插入图片描述

3、堆对象回收

Java对象能否被回收,得看它是否还在被引用。

在这里插入图片描述
demo = null后,再无对Demo对象的引用,可回收。

在这里插入图片描述
执行:

a1 = null
b1 = null

A、B对象被回收,因为方法中无法再通过引用访问到这两个对象了。总之,判断方式:

  • 引用计数法
  • 可达性分析

4、引用计数法

即为每个对象维护一个计数器,对象被引用就+1,置为null了就-1,JVM扫描堆内存,发现数值为0则回收

A a1 = new A();
B b1 = new B():
a1.SetB(b1);

则A的计数器为1,B的计数器为2
在这里插入图片描述
优点:

  • 简单
  • 也是C++的智能指针的实现基础

缺点:

  • +1,-1的维护损耗性能
  • 循环引用时,导致计数器至少为1,对象无法被回收,内存泄漏

在这里插入图片描述

5、可达性分析算法

普通对象A,经一个引用链可以到达GC Root对象,则A不可被回收

在这里插入图片描述

  • GC Root对象即垃圾回收的根对象
  • GC Root对象一般不会被回收,且JVM持有GC Root对象的List列表

GC Root对象包括:

  • 线程对象Thread(引用线程栈帧中的方法参数、局部变量等)

在这里插入图片描述

  • 系统类加载器加载的java.lang.Class对象(引用类中的静态变量)

在这里插入图片描述

  • 监视器对象(引用synchronized锁的对象)

在这里插入图片描述

  • native本地方法调用时使用的全局对象

6、查看GC Root对象

步骤:

  • 阿尔萨斯的heapdump指令,保存堆内存快照到本地磁盘
heapdump d:/tmp/test.hprof
  • 使用MAT工具打开堆内存快照文件

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/603968.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux程序、进程以及计划任务(第一部分)

目录 一、程序和进程 1、什么是程序&#xff1f; 2、什么是进程&#xff1f; 3、线程是什么&#xff1f; 4、如何查看是多线程还是单线程 5、进程结束的两种情况&#xff1a; 6、进程的状态 二、查看进程信息的相关命令 1、ps&#xff1a;查看静态的进程统计信息 2、…

c++基础(对c的扩展)

文章目录 命令空间引用基本本质引用作为参数引用的使用场景 内联函数引出基本概念 函数补充默认参数函数重载c中函数重载定义条件函数重载的原理 命令空间 定义 namespace是单独的作用域 两者不会相互干涉 namespace 名字 { //变量 函数 等等 }eg namespace nameA {int num;v…

判断对象是否是垃圾的引用计数法有什么问题

给对象中添加一个引用计数器&#xff0c;每当有一个地方引用它&#xff0c;计数器就加一&#xff0c;当引用失效计数器就减一&#xff0c;任何时候引用计数器为0的对象就是不可能再被使用的&#xff08;变成垃圾&#xff09;。 这个方法实现简单、效率高&#xff0c;但是目前主…

STM32F407ZGT6-flash地址-SRAM

2、 2-STM32F407英文数据手册&#xff08;没有中文&#xff09;.pdf Memory mapping

抽丝剥茧设计模式

Singleton 单例 饿汉式 最简单的方式 /*** 饿汉式* 类加载到内存后&#xff0c;就实例化一个单例&#xff0c;JVM保证线程安全* 简单实用&#xff0c;推荐使用&#xff01;* 唯一缺点&#xff1a;不管用到与否&#xff0c;类装载时就完成实例化* Class.forName(""…

Leetcode 2998. Minimum Number of Operations to Make X and Y Equal

Leetcode 2998. Minimum Number of Operations to Make X and Y Equal 1. 解题思路2. 代码实现 题目链接&#xff1a;10033. Minimum Number of Operations to Make X and Y Equal 1. 解题思路 这一题就是一个比较简单的动态规划的题目了。 显然&#xff0c;如果x小于y&…

Kafka 基本概念和术语

1、消息 Record&#xff1a;Kafka 是消息引擎嘛&#xff0c;这里的消息就是指 Kafka 处理的主要对象。 2、主题 Topic&#xff1a;主题是承载消息的逻辑容器&#xff0c;在实际使用中多用来区分具体的业务。在Kafka 中发布订阅的对象是 Topic。 3、分区 Partition&#xf…

原子性、CAS操作

Java中的原子性操作 所谓原子性操作&#xff0c;是指执行一系列操作时&#xff0c;这些操作要么全部执行&#xff0c;要么全部不执行&#xff0c;不存在只执行其中一部分的情况。 在设计计数器时一般都先读取当前值&#xff0c;然后1,再更新。 这个过程是读—改—写的过程&a…

python归并排序

归并排序&#xff08;Merge Sort&#xff09;是一种经典的排序算法&#xff0c;它采用分治法的一个非常典型的应用。该算法将已有序的子序列合并&#xff0c;得到完全有序的序列&#xff1b;即先使每个子序列有序&#xff0c;再使子序列段间有序。其基本步骤如下&#xff1a; 1…

msckf-vio 跑Euroc数据集,并用evo进行评估

所需材料&#xff1a; Euroc数据集主页&#xff1a;https://projects.asl.ethz.ch/datasets/doku.php?idkmavvisualinertialdatasetsevo评估工具代码&#xff1a;https://github.com/MichaelGrupp/evo向msckf-vio中添加保存位姿的代码&#xff0c;可参考https://blog.csdn.ne…

C++中使用vector保存新建对象中自指指针的问题

问题 在某些场景中&#xff08;例如并查集&#xff09;&#xff0c;我们需要将新建对象中的指针指向对象自己。例如&#xff0c; struct factor {int data;factor* next;factor(int i) : data(i), next(this){} }; 这样的结构体当然没有问题&#xff0c;如果我们想以类似链表…

分布式锁3: zk实现分布式锁3 使用临时顺序节点+watch监听实现阻塞锁

一 zk实现分布式锁 1.1 使用临时顺序节点 的问题 接上一篇文章&#xff0c;每个请求要想正常的执行完成&#xff0c;最终都是要创建节点&#xff0c;如果能够避免争抢必然可以提高性能。这里借助于zk的临时序列化节点&#xff0c;实现分布式锁 1. 主要修改了构造方法和lock方…

MYSQL 索引使用规则

索引失效 最左前缀法则 where之后写的顺序不重要&#xff0c;存在就可以 范围查询后面的索引查询失效&#xff08;比如>&#xff09;,但是>或者<是不会失效的 不要在索引列上进行运算操作&#xff0c;否则索引失效。 字符串类型字段不加引号索引会失效 尾部模糊匹配…

cgo环境之-安装gcc mingw

下载 到官网下载&#xff1a; 官网 如果你是Windows arm 芯片&#xff0c;可以到这里下载 https://github.com/mstorsjo/llvm-mingw/releases

四、C语言中的数组:数组的输入与元素个数

本章的学习链接如下&#xff1a; 四、C语言中的数组&#xff1a;数组的创建与初始化 1.数组的输入 其实在之前的学习中&#xff0c;我们已经学过了如何用scanf()安全地输入数组&#xff0c;在这一章中我们讲解几种不同的方式。 在 C 语言中&#xff0c;数组的输入通常涉及到…

Spring05

一、Spring事务管理入门 1.1、创建数据库和表 创建一个Spring数据库&#xff0c;在Spring数据库中创建tb_account(账户表)&#xff0c;并初始化数据。 1.2、编写Service层、Mapper层以及调用层 1.2.1、AccountServiceImpl实现了AccountService接口 1.2.2、Mapper层中的代码 1…

数据分析概述

目录 1.数据分析的基本类型&#xff1a;2.数据分析的实现方式&#xff1a;3.机器学习和统计学的区别&#xff1a;3.1统计学3.2机器学习 小结&#xff1a; 1.数据分析的基本类型&#xff1a; 这就不得不提到Gartner分析学价值扶梯模型了&#xff0c;这个模型从复杂度和价值两个…

端口开放问题

端口开放问题 所遇问题 在宿主主机上可以ping通虚拟机ip192.168.27.129&#xff0c;但无法在宿主主机上访问http://192.168.27.129:8080navavcat 16连接mysql时&#xff0c;2002 - Can’t connect to server on ‘192.168.27.129’(100601&#xff09; 原因 以上两个问题&a…

树莓派4B使用ncnn部署yolov5-Lite,推理耗时 247ms 包含前后处理

一. 引言 最近在玩树莓派&#xff0c;想在树莓派上不是一个目标检测算法&#xff0c;大致看了一下&#xff0c;目前开源的大家都在使用yolov5-Lite&#xff0c;使用ncnn去推理加速&#xff0c;于是自己也尝试部署&#xff0c;在此记录一下&#xff0c;个人踩的坑。 二. 版本选…