垃圾回收算法有哪些?每个算法各自有何优劣?

本文介绍了Java垃圾回收机制,包括引用计数法和可达性分析法,并详细讲解了三种主要的垃圾回收算法:标记-清理法,标记-整理法,以及复制算法,分析了它们的优缺点。在可达性分析法中,GC Roots对象如虚拟机栈、类静态属性、常量引用和本地方法栈中的JNI引用是关键。

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

 1.在探讨垃圾回收算法之前,首先需要介绍一下垃圾回收机制

2.我们知道对无用的对象,可以进行回收然后释放空间,所以需要确定哪些对象是需要被回收的

   垃圾回收机制:

      1、引用计数法:当对象被引用,程序计数器+1;释放-1;当为0时证明对象未被引用,可回收

   

但是这个算法有明显的缺陷,对于循环引用的情况下,对象不会被回收

例如下图:对象A,对象B循环引用,没有其他的对象引用A和B,但是A和B都不会被回收

 

      2、可达性分析法:通过一些列称之为“GC Roots” 的对象作为起点;从此起点向下搜索,所走过的路径称之为引用链,当一个对象到 GC Roots 没有任何引用链相连接,代表此对象不可达。

     

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值