esp-idf的内存管理——tlsf算法

15 篇文章 24 订阅 ¥9.90 ¥99.00
本文详细介绍了ESP-IDF中用于嵌入式系统的TLSF内存管理算法,探讨了旧版堆管理器的不足,以及TLSF算法如何通过两级分离策略提高内存分配和释放效率。文章详细阐述了TLSF算法的结构、内存块管理、位图索引计算、堆创建与销毁、内存申请与释放的过程,并讨论了内存对齐申请的处理。TLSF算法在保证内部碎片可控的同时,实现了O(1)时间复杂度的内存操作,提高了RTOS环境下的性能。
摘要由CSDN通过智能技术生成

1 最初还不是tlsf

早几年(2019年之前)idf使用的堆管理器实现很简单,使用一个链表将所有(空闲和非空闲)的内存块串起来。对此,已经有同学分析过,可以参考这篇博客:esp32 heap 内存管理简析。下面这张图也是来自这篇博客,一目了然:
在这里插入图片描述

2 为什么要引入tlsf

旧的堆管理器的实现比较简单,性能一般,无论是申请还是释放都需要遍历整个堆,时间复杂度是O(N),这对于RTOS是难以接受的。对此,有很多改进的方向:

  • free list
  • separate fit
  • two level separate fit

可以认为上述三种堆管理器的实现是层层改进的。free list只会将空闲的内存块串起来,减少了申请和释放时需要遍历的链表长度。separa

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值