0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線(xiàn)課程
  • 觀(guān)看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

heap_1內(nèi)存分配方法

麥辣雞腿堡 ? 來(lái)源:嵌入式Linux系統(tǒng)開(kāi)發(fā) ? 作者:嵌入式Linux系統(tǒng)開(kāi) ? 2023-07-30 10:33 ? 次閱讀

heap_1 內(nèi)存分配方法

動(dòng) 態(tài) 內(nèi) 存 分 配 需 要 一 個(gè) 內(nèi) 存 堆 , FreeRTOS 中 的 內(nèi) 存 堆 為 ucHeap[] , 大 小 為configTOTAL_HEAP_SIZE,這個(gè)前面講 FreeRTOS 配置的時(shí)候就講過(guò)了。不管是哪種內(nèi)存分配方法,它們的內(nèi)存堆都為 ucHeap[],而且大小都是 configTOTAL_HEAP_SIZE。內(nèi)存堆在文件heap_x.c(x 為 1~5)中定義的,比如 heap_1.c 文件就有如下定義:

#if(configAPPLICATION_ALLOCATED_HEAP==1)

extern

uint8_t

ucHeap[configTOTAL_HEAP_SIZE];

//需要用戶(hù)自行定義內(nèi)存堆

#else

static

uint8_t

ucHeap[configTOTAL_HEAP_SIZE];

//編譯器決定

#endif

當(dāng)宏 configAPPLICATION_ALLOCATED_HEAP 為 1 的時(shí)候需要用戶(hù)自行定義內(nèi)存堆,否則的話(huà)由編譯器來(lái)決定,默認(rèn)都是由編譯器來(lái)決定的。如果自己定義的話(huà)就可以將內(nèi)存堆定義到外部 SRAM 或者 SDRAM 中。

heap_1 實(shí)現(xiàn)起來(lái)就是當(dāng)需要 RAM 的時(shí)候就從一個(gè)大數(shù)組(內(nèi)存堆)中分一小塊出來(lái),大數(shù)組(內(nèi)存堆)的容量為 configTOTAL_HEAP_SIZE。使用函數(shù) xPortGetFreeHeapSize() 可以獲取內(nèi)存堆中剩余內(nèi)存大小。

heap_1 特性如下:

1、適用于那些一旦創(chuàng)建好任務(wù)、信號(hào)量和隊(duì)列就再也不會(huì)刪除的應(yīng)用,實(shí)際上大多數(shù)的 FreeRTOS 應(yīng)用都是這樣的。

2、具有可確定性(執(zhí)行所花費(fèi)的時(shí)間大多數(shù)都是一樣的),而且不會(huì)導(dǎo)致內(nèi)存碎片。

3、代碼實(shí)現(xiàn)和內(nèi)存分配過(guò)程都非常簡(jiǎn)單,內(nèi)存是從一個(gè)靜態(tài)數(shù)組中分配到的,也就是適合于那些不需要?jiǎng)討B(tài)內(nèi)存分配的應(yīng)用。

如果使用 heap_1,一旦申請(qǐng)內(nèi)存成功就不允許釋放!但是 heap_1 的內(nèi)存分配過(guò)程簡(jiǎn)單,如此看來(lái) heap_1 似乎毫無(wú)任何使用價(jià)值啊。千萬(wàn)不能這么想,有很多小型的應(yīng)用在系統(tǒng)一開(kāi)始就創(chuàng)建好任務(wù)、信號(hào)量或隊(duì)列等,在程序運(yùn)行的整個(gè)過(guò)程這些任務(wù)和內(nèi)核對(duì)象都不會(huì)刪除,那么這個(gè)時(shí)候使用 heap_1 就很合適的。

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀(guān)點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 嵌入式
    +關(guān)注

    關(guān)注

    5052

    文章

    18916

    瀏覽量

    300819
  • 內(nèi)存
    +關(guān)注

    關(guān)注

    8

    文章

    2947

    瀏覽量

    73733
  • FreeRTOS
    +關(guān)注

    關(guān)注

    12

    文章

    483

    瀏覽量

    61855
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    C語(yǔ)言知識(shí)總結(jié):動(dòng)態(tài)內(nèi)存分配

    動(dòng)態(tài)內(nèi)存分配就 是指在程序執(zhí)行的過(guò)程中動(dòng)態(tài)地分配或者回收存儲(chǔ)空間的分配內(nèi)存方法。動(dòng)態(tài)
    發(fā)表于 10-24 15:52 ?813次閱讀

    請(qǐng)問(wèn)cmd中heap默認(rèn)是在哪個(gè)段分配呢?

    我cmd文件分配如下,請(qǐng)問(wèn):1 stack分配是根據(jù)在子函數(shù)中用到的最大的局部變量,比如數(shù)組大小來(lái)分配的么?而heap
    發(fā)表于 10-25 09:53

    基于FreeRTOS內(nèi)存管理Heap_4.c的實(shí)現(xiàn)方法

    Heap_4.c,發(fā)現(xiàn)它的實(shí)現(xiàn)方法還挺簡(jiǎn)單的,而且比較實(shí)用,不過(guò)為了要像原子哥的內(nèi)存管理那樣管理三個(gè)內(nèi)存池,還需要稍稍修改一下,我已經(jīng)修改好了,測(cè)試了一下沒(méi)發(fā)現(xiàn)問(wèn)題,上傳上來(lái)給大家瞧瞧
    發(fā)表于 07-15 21:46

    嵌入式系統(tǒng)內(nèi)存分配方式是怎樣的

    一篇講透嵌入式系統(tǒng)內(nèi)存分配方
    發(fā)表于 12-17 07:40

    一種嵌入式系統(tǒng)的內(nèi)存分配方

    嵌入式系統(tǒng)中對(duì)實(shí)時(shí)性的保證,要求內(nèi)存分配過(guò)程要盡可能地快。因此在嵌入式系統(tǒng)中,不可能采用通用操作系統(tǒng)中復(fù)雜而完善的內(nèi)存分配策略,一般都采用簡(jiǎn)單、快速的
    發(fā)表于 05-24 14:30 ?2275次閱讀

    FreeRTOS代碼剖析之1內(nèi)存管理Heap

    FreeRTOS8.0.1進(jìn)行剖析研究。參考資料為《Using the FreeRTOS Real Time Kernel-A Practical Guide opened》。 Heap_1.c的注釋說(shuō)明,Heap_1
    發(fā)表于 02-09 05:25 ?889次閱讀
    FreeRTOS代碼剖析之<b class='flag-5'>1</b>:<b class='flag-5'>內(nèi)存</b>管理<b class='flag-5'>Heap</b>

    FreeRTOS代碼剖析之2:內(nèi)存管理Heap

    在FreeRTOS8.0.1這個(gè)版本中,一共有四個(gè)內(nèi)存堆模型。這一次講的就是第二個(gè)模型Heap_2.c。從一開(kāi)始就可以看到注釋中對(duì)Heap_2的模型解釋?zhuān)哼@是對(duì)pvPortMalloc
    發(fā)表于 02-09 05:28 ?783次閱讀
    FreeRTOS代碼剖析之2:<b class='flag-5'>內(nèi)存</b>管理<b class='flag-5'>Heap</b>

    淺談內(nèi)存分配方式 避免內(nèi)存浪費(fèi)問(wèn)題

    說(shuō)到內(nèi)存分配方式,就不得不提連續(xù)分配方式。這種方式是指為一個(gè)用戶(hù)程序分配一個(gè)連續(xù)的內(nèi)存空間,它曾被廣泛的用于20世紀(jì)60~70年代的OS中
    發(fā)表于 03-03 11:22 ?1405次閱讀

    什么是堆內(nèi)存?堆內(nèi)存是如何分配的?

    在一般的編譯系統(tǒng)中,堆內(nèi)存分配方向和棧內(nèi)存是相反的。當(dāng)棧內(nèi)存從高地址向低地址增長(zhǎng)的時(shí)候,堆內(nèi)存從低地址向高地址
    的頭像 發(fā)表于 07-05 17:58 ?9863次閱讀

    韋東山freeRTOS系列教程之內(nèi)存管理(2)

    文章目錄 教程目錄 2.1 為什么要自己實(shí)現(xiàn)內(nèi)存管理 2.2 FreeRTOS的5種內(nèi)存管理方法 2.2.1 Heap_1 2.2.2 Heap
    發(fā)表于 11-29 16:58 ?977次閱讀
    韋東山freeRTOS系列教程之<b class='flag-5'>內(nèi)存</b>管理(2)

    heap_2內(nèi)存的特性與分配方法

    heap_2 內(nèi)存分配方法 heap_2 提供了一個(gè)更好的分配算法,不像 heap_1那樣,
    的頭像 發(fā)表于 07-30 10:36 ?572次閱讀

    FreeRTOS heap_3內(nèi)存分配方法

    heap_3 內(nèi)存分配方法 這個(gè)分配方法是對(duì)標(biāo)準(zhǔn) C 中的函數(shù) malloc()和 free()的簡(jiǎn)單封裝,F(xiàn)reeRTOS 對(duì)這兩個(gè)函數(shù)做了線(xiàn)程保護(hù)。
    的頭像 發(fā)表于 07-30 10:40 ?675次閱讀
    FreeRTOS <b class='flag-5'>heap</b>_3<b class='flag-5'>內(nèi)存</b><b class='flag-5'>分配方法</b>

    heap_4內(nèi)存分配方法介紹

    heap_4 內(nèi)存分配方法 heap_4 提供了一個(gè)最優(yōu)的匹配算法,不像 heap_2,heap
    的頭像 發(fā)表于 07-30 10:42 ?809次閱讀

    FreeRTOS heap_5內(nèi)存分配方法介紹

    heap_5 內(nèi)存分配方法 heap_5 使用了和 heap_4 相同的合并算法,內(nèi)存管理實(shí)現(xiàn)起
    的頭像 發(fā)表于 07-30 10:47 ?958次閱讀

    如何自定義內(nèi)存控制器的設(shè)置

    在FreeRTOS中自定義內(nèi)存控制器的設(shè)置,主要涉及到內(nèi)存分配策略的選擇和配置。FreeRTOS提供了多種內(nèi)存分配策略,如
    的頭像 發(fā)表于 09-02 14:28 ?273次閱讀