高效内存分配机制

Efficient_memory_allocation

高效内存分配机制

​ 由于需要在单片机上使用malloc,但自带的malloc机制速度太慢且需要还需要配置堆,当某些代码需要使用这个功能时候就需要对应的单片机打开,这样不利于模块与平台的解耦。

​ 不知道为什么系统自带的malloc耗时居然和申请的内存大小成正比,这个在小数据申请的时候倒没什么,但是当要高速申请大内存时候就懵逼了,而且在pc上感觉不出来,但是在MCU这种单片机上使用的时候就感觉出来了,故此我自己写了一个开源的高效的内存分配模块。

​ 这个模块的用法和malloc与free一样,但不同的是它可以指定内存存放的地址,比如外部ram。然后在大内存分配方面不随内存申请大小变化,同时在使用的时候自动整理内存碎片。

​ 内存碎片我并没有采用搬移的方式,那样子会额外消耗cpu的运算资源,而是在每次释放内存的时候自动将临近的零碎内存进行吸收,就像磁铁一样逐步整理。

​ 但,内存碎片整理是需要花费时间的,而很多时候malloc出来的内存使用了一下就free掉了,因此为了减少时间,只有当内存满了后才使用碎片内存,其他时候都是直接申请新内存。

​ 若有新的想法和建议欢迎指教,我们一起来制作一个高效的内存分配器。

image-20211108192841644
git地址:http://height.xiaomaapp.top:7112/summary/libraries%2FEfficient_memory_allocation.git

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值