malloc_consolidate

此文章用于详细介绍malloc_consolidate。

众所周知,fastbin一般是不能合并,但在malloc_consolidate中是个例外。

1.触发机制

首先构造这样的堆块结构

一个0x40的堆块在fastbin中,一个0x110的堆块在unbin中

随后我们尝试分配一个0x300的堆块。

可以看到0x110的usbin被丢到了smallbin中,fastbin没有被合并

但我们试着改成分配0x500的堆块。

可以看到fastbin和usbin完成了合并,并被放到了smallbin中。

得出结论:当你malloc一个大于smallbin的堆块,它会将fastbin拿到usbin中,让它尝试与周围的堆块合并,如果没被分配,就扔到适当的bin中。

这里可能有人会有疑惑:如果fastbin不能合并,是否还会被分配到smallbin中?fastbin之间在这种情况下能否合并?

开始试验:

这次我们只free一个fastbin,然后再尝试malloc(0x500),以下是结果。

可以看到,即使fastbin不参与合并,也会被先被拉进usbin,然后被扔到smallbin中。

接下来进行第二个实验:

我们先释放了2个fastbin,然后再尝试malloc(0x500),以下是结果:

即使是fastbin之间,也会进行合并!

2.补充

之前一直以为fastbin自身的pre_inuse一直是1,所以一直在想合并的时候fastbin怎么识别前面的chunk是不是freechunk。

但经过试验发现,当前面的chunk是freechunk并且不是fastbin的时候,自身的pre_inuse为0,只是不参与合并。

当一个chunk被free时,若它属于fastbin,则它的下一个chunk的pre_inuse位不会被改变。

  • 10
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值