JVM学习(4)-垃圾回收算法

java语言的一大特点就是可以进行自动垃圾回收处理,垃圾收集器可以有多种不同的实现,本文主要介绍一下回收算法。

1.引用计数法:对于一个对象,判断是否有引用,如果有计数器+1。引用失效则计数器-1。缺点在于存在两个或多个该回收的对象互相引用的情况,此时按照引用计数法无法处理。

2.标志-清除算法:该方法将垃圾回收分为两个阶段,标记阶段和清除状态。在标记阶段,首先通过根节点,标记所有从根节点开始的可达状态,未被标记的对象就是未被引用的垃圾对象,在清除阶段,清除所有未被标记的对象,缺点在于可能存在空间碎片即回收后的空间不连续

3.复制算法:将原有的内存空间分为两块,每次使用一块,在垃圾回收时,将正在使用的内存中的存活对象复制到未使用的内存块中,之后清除正在使用的内存块所有对象,交换两个内存的角色完成垃圾回收,适合新生代。

4.标记-压缩算法:在标记-清除算法上的清除后加了重新排序可用对象的步骤。

5.增量算法:让垃圾回收线程和应用程序线程交替执行。

6.分代算法:内存区间根据对象的特点分为几块,每块根据自身特点使用不同的回收算法,以提高垃圾回收的效率。

©️2022 CSDN 皮肤主题:大白 设计师:CSDN官方博客 返回首页

打赏作者

itunewu

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值