图解GC加强版标记清除算法之多个空闲链表法,位图标记法,延迟清除法

    上篇文章我们学习到典型的垃圾回收标记-清除算法,该算法实现简单,与保守式GC算法兼容。但是存在易碎片化,分配速度慢和与写时复制技术(像mysql中保持一致性读原理类似)不兼容的问题。

这篇文章我们来学习改进型标记-清除算法。

多个空闲链表

   典型的标记-清除算法只用到一个空闲链表,在这个链表中大大小小的空间都由一个链表串在一起,系统进行空间分配时最差的时间复杂度是O(N)。这里我们

可以利用最常见的空间换时间的做法加以改进。我们对每个堆空间按照其大小进行分类,例如占1字节内存空间为一类,占用2字节内存空间为一类。以此划分对每一类

建立空闲链表进行串联。而链表头我们可以建立一个数组以其index为类别标志保存每个链表头。而至于其他较大且并不常存的内存我们可以设置一个阈值,一旦超过这个

阈值我们可以归结到数组最后的位置上。

   

位图标记法:

    在典型的GC标记算法中不兼容写时复制技术主要是因为即使没有重写对象,GC也会设置所有活动对象的标志位,这样频繁且不该有点复制将压迫到内存空间。

为了处理这个问题,我们采用

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大学一年级

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

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

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

打赏作者

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

抵扣说明:

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

余额充值