0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

heap_2内存的特性与分配方法

麦辣鸡腿堡 来源:嵌入式Linux系统开发 作者:嵌入式Linux系统开 2023-07-30 10:36 次阅读

heap_2 内存分配方法

heap_2 提供了一个更好的分配算法,不像 heap_1那样,heap_2 提供了内存释放函数。heap_2 不会把释放的内存块合并成一个大块,这样有一个缺点,随着你不断的申请内存,内存堆就会被分为很多个大小不一的内存(块),也就是会导致内存碎片!

heap_2 的特性如下:

1、可以使用在那些可能会重复的删除任务、队列、信号量等的应用中,要注意有内存碎片产生!

2、如果分配和释放的内存 n 大小是随机的,那么就要慎重使用了,比如下面的示例:

● 如果一个应用动态的创建和删除任务,而且任务需要分配的堆栈大小都是一样的,那么 heap_2 就非常合适。如果任务所需的堆栈大小每次都是不同,那么 heap_2 就不适合了,因为这样会导致内存碎片产生,最终导致任务分配不到合适的堆栈!

● 如果一个应用中所使用的队列存储区域每次都不同,那么 heap_2 就不适合了,和上面一样。

● 应用需要调用 pvPortMalloc()和 vPortFree()来申请和释放内存,而不是通过其他 FreeRTOS 的其他 API 函数来间接的调用,这种情况下 heap_2 不适合。

3、如果应用中的任务、队列、信号量和互斥信号量具有不可预料性(如所需的内存大小不能确定,每次所需的内存都不相同,或者说大多数情况下所需的内存都是不同的)的话可能会导致内存碎片。

4、具有不可确定性,但是也远比标准 C 中的 mallo()和 free()效率高!heap_2 基本上可以适用于大多数的需要动态分配内存的工程中,而 heap_4 更是具有将内存碎片合并成一个大的空闲内存块(就是内存碎片回收)的功能。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 嵌入式
    +关注

    关注

    4982

    文章

    18281

    浏览量

    288430
  • 内存
    +关注

    关注

    8

    文章

    2767

    浏览量

    72764
  • FreeRTOS
    +关注

    关注

    12

    文章

    473

    浏览量

    61347
收藏 人收藏

    评论

    相关推荐

    C语言知识总结:动态内存分配

    动态内存分配就 是指在程序执行的过程中动态地分配或者回收存储空间的分配内存方法。动态
    发表于 10-24 15:52 654次阅读

    请问cmd中heap默认是在哪个段分配呢,动态分配段名是什么?

    我cmd文件分配如下,请问:1 stack分配是根据在子函数中用到的最大的局部变量,比如数组大小来分配的么?而heap分配是根据malloc
    发表于 07-30 07:55

    请问cmd中heap默认是在哪个段分配呢?

    我cmd文件分配如下,请问:1 stack分配是根据在子函数中用到的最大的局部变量,比如数组大小来分配的么?而heap分配是根据malloc
    发表于 10-25 09:53

    基于FreeRTOS内存管理Heap_4.c的实现方法

    fragmentation.)不过经过这一次的剖析之后,发现Heap_4所用的内存管理算法为首次适配法(first fit algorithm)。和Heap_2一样,Heap_4先申
    发表于 07-15 21:46

    嵌入式系统内存分配方式是怎样的

    一篇讲透嵌入式系统内存分配方
    发表于 12-17 07:40

    一种嵌入式系统的内存分配方

    嵌入式系统中对实时性的保证,要求内存分配过程要尽可能地快。因此在嵌入式系统中,不可能采用通用操作系统中复杂而完善的内存分配策略,一般都采用简单、快速的
    发表于 05-24 14:30 2029次阅读

    基于费用最优的功率变换器可靠性分配方法_杜贵平

    基于费用最优的功率变换器可靠性分配方法_杜贵平
    发表于 12-31 14:44 0次下载

    FreeRTOS代码剖析之1:内存管理Heap

    _1.c只是简单地实现了pvPortMalloc()这一个函数,这个堆的实现方案并不允许已分配内存再次被释放。(The simplest possible implementation of pvPortMalloc(). Note that this implemen
    发表于 02-09 05:25 765次阅读
    FreeRTOS代码剖析之1:<b class='flag-5'>内存</b>管理<b class='flag-5'>Heap</b>

    FreeRTOS代码剖析之2:内存管理Heap

    在FreeRTOS8.0.1这个版本中,一共有四个内存堆模型。这一次讲的就是第二个模型Heap_2.c。从一开始就可以看到注释中对Heap_2的模型解释:这是对pvPortMalloc
    发表于 02-09 05:28 629次阅读
    FreeRTOS代码剖析之2:<b class='flag-5'>内存</b>管理<b class='flag-5'>Heap</b>

    浅谈内存分配方式 避免内存浪费问题

    说到内存分配方式,就不得不提连续分配方式。这种方式是指为一个用户程序分配一个连续的内存空间,它曾被广泛的用于20世纪60~70年代的OS中
    发表于 03-03 11:22 1273次阅读

    什么是堆内存?堆内存是如何分配的?

    在一般的编译系统中,堆内存分配方向和栈内存是相反的。当栈内存从高地址向低地址增长的时候,堆内存从低地址向高地址
    的头像 发表于 07-05 17:58 9518次阅读

    heap_1内存分配方法

    heap_1 内存分配方法 动 态 内 存 分 配 需 要 一 个 内 存 堆 , FreeRTOS 中 的 内 存 堆 为 ucHeap
    的头像 发表于 07-30 10:33 376次阅读

    FreeRTOS heap_3内存分配方法

    heap_3 内存分配方法 这个分配方法是对标准 C 中的函数 malloc()和 free()的简单封装,FreeRTOS 对这两个函数做了线程保护。
    的头像 发表于 07-30 10:40 413次阅读
    FreeRTOS <b class='flag-5'>heap</b>_3<b class='flag-5'>内存</b><b class='flag-5'>分配方法</b>

    heap_4内存分配方法介绍

    heap_4 内存分配方法 heap_4 提供了一个最优的匹配算法,不像 heap_2heap
    的头像 发表于 07-30 10:42 501次阅读

    FreeRTOS heap_5内存分配方法介绍

    heap_5 内存分配方法 heap_5 使用了和 heap_4 相同的合并算法,内存管理实现起
    的头像 发表于 07-30 10:47 574次阅读