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

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

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

RT-Thread內(nèi)存管理的學(xué)習(xí)過(guò)程總結(jié)

RTThread物聯(lián)網(wǎng)操作系統(tǒng) ? 來(lái)源:RTThread物聯(lián)網(wǎng)操作系統(tǒng) ? 作者:RTThread物聯(lián)網(wǎng)操作 ? 2021-03-02 14:13 ? 次閱讀

單片機(jī)芯片上,如果不考慮出廠固化的ROM空間的話,通常開(kāi)發(fā)者能接觸到的存儲(chǔ)空間主要分兩種:掉電可保存數(shù)據(jù)的片內(nèi)FLASH和掉電不可保存數(shù)據(jù)的片內(nèi)RAM

片內(nèi)RAM(通常理解為內(nèi)存)的訪問(wèn)速度比較快,可以按照變量地址隨機(jī)訪問(wèn),但斷電后數(shù)據(jù)丟失。片內(nèi)FLASH(通常理解為硬盤(pán))所保存的內(nèi)容比較固定,主要用來(lái)保存程序本身的數(shù)據(jù)內(nèi)容,保存的內(nèi)容斷電不丟失。

對(duì)于單片機(jī)的片內(nèi)RAM內(nèi)存,主要有堆和棧之分,本章的內(nèi)存管理,主要是基于堆內(nèi)存管理進(jìn)行開(kāi)展的,在RT-Thread中,有兩種堆內(nèi)存管理方式:動(dòng)態(tài)內(nèi)存堆管理和靜態(tài)內(nèi)存池管理。

本文嘗試從以下幾個(gè)方面總結(jié)一下RT-Thread內(nèi)存管理的學(xué)習(xí)過(guò)程

內(nèi)存管理相關(guān)介紹

在運(yùn)行操作系統(tǒng)的單片機(jī)上面,代碼和變量會(huì)占用一部分固定的內(nèi)存開(kāi)銷,操作系統(tǒng)在初始化的時(shí)候,會(huì)去除掉這部分已經(jīng)占用的內(nèi)存,把剩下的閑置內(nèi)存納入到系統(tǒng)堆里面進(jìn)行統(tǒng)一管理,不管是動(dòng)態(tài)堆內(nèi)存,還是靜態(tài)內(nèi)存池,都是使用這部分閑置空間的。

由于在實(shí)時(shí)操作系統(tǒng)里面對(duì)時(shí)間的要求十分嚴(yán)格,為了保證內(nèi)存分配的時(shí)候不影響系統(tǒng)的實(shí)時(shí)性,就需要確保分配內(nèi)存的時(shí)間是確定并可控的;并且在內(nèi)存分配達(dá)到一定次數(shù)后,就不可避免地產(chǎn)生內(nèi)存碎片;與此同時(shí),嵌入式設(shè)備的內(nèi)存資源相對(duì)有限,有些系統(tǒng)只有幾十KB內(nèi)存,而有些系統(tǒng)則有幾十MB。

所以,為了解決以上內(nèi)存分配可能出現(xiàn)的問(wèn)題,需要使用一些內(nèi)存管理算法來(lái)進(jìn)行這些內(nèi)存分配管理,RT-Thread提供了兩種內(nèi)存管理方式,分別是:動(dòng)態(tài)內(nèi)存堆管理和靜態(tài)內(nèi)存池管理。

動(dòng)態(tài)內(nèi)存堆管理

內(nèi)存堆管理分配主要用于系統(tǒng)動(dòng)態(tài)分配內(nèi)存的場(chǎng)合,比如,我們使用動(dòng)態(tài)方式創(chuàng)建某些內(nèi)核對(duì)象(如消息隊(duì)列,郵箱,信號(hào)量,等等)的時(shí)候,所使用到的內(nèi)存空間就是動(dòng)態(tài)內(nèi)存堆。動(dòng)態(tài)內(nèi)存堆的意思是,要用多少,系統(tǒng)就分配多少給你,不用的時(shí)候,就要進(jìn)行釋放,還給系統(tǒng)再進(jìn)行統(tǒng)一管理。

關(guān)于動(dòng)態(tài)內(nèi)存堆的管理,主要有三種算法:小內(nèi)存分配算法,slab算法,memheap算法。關(guān)于這三種管理算法的實(shí)現(xiàn)原理介紹,RT-Thread官方已經(jīng)給出了比較詳細(xì)的解釋,這里不再重復(fù)論述。

c7598cd6-772b-11eb-8b86-12bb97331649.png

需要注意的是,這三種內(nèi)存管理算法,我們只能通過(guò)menuconfig來(lái)配置系統(tǒng)內(nèi)核,選擇其中一種內(nèi)存管理方法,對(duì)于用戶的應(yīng)用程序接口而言,這三種算法是透明的,也就是說(shuō)提供給用戶的內(nèi)存管理接口是相同的,只是算法的實(shí)現(xiàn)原理不同。

關(guān)于動(dòng)態(tài)堆內(nèi)存管理,操作系統(tǒng)提供了以下API接口函數(shù),如下圖所示。

c81ed086-772b-11eb-8b86-12bb97331649.png

靜態(tài)內(nèi)存池管理

在使用動(dòng)態(tài)內(nèi)存堆管理系統(tǒng)內(nèi)存的時(shí)候,這種方式非常靈活和方便,想用內(nèi)存的時(shí)候就向系統(tǒng)申請(qǐng)分配,不用的時(shí)候就釋放還給系統(tǒng),但這種方式也存在一定的弊端。

主要是向系統(tǒng)申請(qǐng)內(nèi)存的時(shí)候,都要遍歷一次空閑內(nèi)存的鏈表,查找可用的內(nèi)存塊,然后再分配給用戶,而且這種方式不可避免地會(huì)產(chǎn)生內(nèi)存碎片,所以這種內(nèi)存管理方式的效率不是很高。這是一種“用時(shí)間換空間”的內(nèi)存管理方式。

為了提高內(nèi)存的分配效率,RT-Thread提供了靜態(tài)內(nèi)存池管理的方式。靜態(tài)內(nèi)存池就是系統(tǒng)把自身管理的內(nèi)存預(yù)先劃分為多個(gè)固定大小的內(nèi)存塊,當(dāng)用戶需要申請(qǐng)內(nèi)存的時(shí)候,就從這些固定大小的內(nèi)存塊里面申請(qǐng)。

靜態(tài)內(nèi)存池管理的方式,還支持線程掛起操作,當(dāng)系統(tǒng)沒(méi)有內(nèi)存塊可用時(shí),線程就會(huì)掛起等待,直到能申請(qǐng)到可用的內(nèi)存塊,這種特性可以用做線程間同步。

關(guān)于靜態(tài)內(nèi)存池的工作機(jī)制,如下圖所示。

RT-Thread提供了以下API函數(shù)接口,用于靜態(tài)內(nèi)存池管理。

c8eae3ce-772b-11eb-8b86-12bb97331649.png

內(nèi)存堆和內(nèi)存池的應(yīng)用示例

內(nèi)存管理相關(guān)的應(yīng)用示例,主要是為了驗(yàn)證動(dòng)態(tài)內(nèi)存堆管理和靜態(tài)內(nèi)存池管理相關(guān)的API函數(shù)接口,這里包含兩個(gè)示例,分別是內(nèi)存堆管理示例和內(nèi)存池管理示例。

示例源碼下載鏈接:

https://github.com/embediot/rtthread_study_notes

https://gitee.com/embediot/rtthread_study_notes

內(nèi)存堆管理示例會(huì)創(chuàng)建一個(gè)動(dòng)態(tài)的線程,這個(gè)線程會(huì)動(dòng)態(tài)申請(qǐng)內(nèi)存并釋放,每次申請(qǐng)更大的內(nèi)存,當(dāng)申請(qǐng)不到的時(shí)候就結(jié)束。例程中分配內(nèi)存成功并打印信息;當(dāng)試圖申請(qǐng) 65536 byte 即 64KB 內(nèi)存時(shí),由于開(kāi)發(fā)板的單片機(jī) RAM 總大小只有 64K,而可用 RAM 小于 64K,所以分配失敗。

內(nèi)存池管理示例會(huì)創(chuàng)建一個(gè)靜態(tài)的內(nèi)存池對(duì)象,2 個(gè)動(dòng)態(tài)線程。一個(gè)線程會(huì)試圖從內(nèi)存池中獲得內(nèi)存塊,另一個(gè)線程釋放內(nèi)存塊內(nèi)存塊??偣渤跏蓟?4096 /(80+4) = 48 個(gè)內(nèi)存塊。

1、線程 1 申請(qǐng)了 48 個(gè)內(nèi)存塊之后,此時(shí)內(nèi)存塊已經(jīng)被用完,需要其他地方釋放才能再次申請(qǐng);但此時(shí),線程 1 以一直等待的方式又申請(qǐng)了 1 個(gè),由于無(wú)法分配,所以線程 1 掛起;

2、線程 2 開(kāi)始執(zhí)行釋放內(nèi)存的操作;當(dāng)線程 2 釋放一個(gè)內(nèi)存塊的時(shí)候,就有一個(gè)內(nèi)存塊空閑出來(lái),喚醒線程 1 申請(qǐng)內(nèi)存,申請(qǐng)成功后再申請(qǐng),線程 1 又掛起,再循環(huán)一次步驟2;

3、線程 2 繼續(xù)釋放剩余的內(nèi)存塊,釋放完畢。

在memory_test.h頭文件里面,通過(guò)打開(kāi)相應(yīng)的宏定義開(kāi)關(guān),重新編譯工程源碼,下載到開(kāi)發(fā)板即可驗(yàn)證實(shí)驗(yàn)現(xiàn)象,如下圖所示。

內(nèi)存管理相關(guān)注意事項(xiàng)

在使用RT-Thread內(nèi)存管理相關(guān)接口的時(shí)候,為了確保系統(tǒng)穩(wěn)定性,有以下注意事項(xiàng):

1、由于系統(tǒng)為了保證內(nèi)存在多線程的狀態(tài)下能安全分配,引入了互斥操作,因此不能在中斷服務(wù)程序里面分配或釋放內(nèi)存塊,否則會(huì)引起當(dāng)前線程被掛起。

2、在使用內(nèi)存堆管理的時(shí)候,產(chǎn)生的內(nèi)存碎片會(huì)在系統(tǒng)空閑線程運(yùn)行的時(shí)候進(jìn)行回收。

3、用戶應(yīng)用程序在申請(qǐng)內(nèi)存分配的時(shí)候,建議判斷是否申請(qǐng)成功,并對(duì)申請(qǐng)成功的內(nèi)存空間進(jìn)行初始化后再使用。

4、動(dòng)態(tài)內(nèi)存堆管理是一種“用時(shí)間換空間”的內(nèi)存管理方式,這種方式可以節(jié)省一定的內(nèi)存空間,但會(huì)損失一點(diǎn)效率。

5、靜態(tài)內(nèi)存池管理是一種“用空間換時(shí)間”的內(nèi)存管理方式,這種方式相對(duì)來(lái)說(shuō)比較高效,但會(huì)造成一定的空間浪費(fèi)。

6、對(duì)于以KB為單位的單片機(jī)片內(nèi)RAM內(nèi)存,一般采用動(dòng)態(tài)內(nèi)存堆里面的小內(nèi)存管理算法即可。

原文標(biāo)題:【RT-Thread學(xué)習(xí)筆記】RT-Thread內(nèi)存管理學(xué)習(xí)總結(jié)

文章出處:【微信公眾號(hào):RTThread物聯(lián)網(wǎng)操作系統(tǒng)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

責(zé)任編輯:haq

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

    關(guān)注

    8

    文章

    3052

    瀏覽量

    74246
  • RT-Thread
    +關(guān)注

    關(guān)注

    31

    文章

    1305

    瀏覽量

    40331
  • RTThread
    +關(guān)注

    關(guān)注

    8

    文章

    132

    瀏覽量

    40975

原文標(biāo)題:【RT-Thread學(xué)習(xí)筆記】RT-Thread內(nèi)存管理學(xué)習(xí)總結(jié)

文章出處:【微信號(hào):RTThread,微信公眾號(hào):RTThread物聯(lián)網(wǎng)操作系統(tǒng)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    RT-Thread上CAN實(shí)踐

    開(kāi)箱測(cè)試RT-Thread官方已完成了對(duì)英飛凌XMC7200EVK的移植,通過(guò)shell可以看到做好了uart3的console。本文將介紹如何進(jìn)行RT-ThreadCan移植。接下來(lái)我們要完成CAN_FD的驅(qū)動(dòng)移植,并正常啟動(dòng)RT-T
    的頭像 發(fā)表于 11-13 01:03 ?1351次閱讀
    <b class='flag-5'>RT-Thread</b>上CAN實(shí)踐

    開(kāi)源共生 商業(yè)共贏 | RT-Thread 2024開(kāi)發(fā)者大會(huì)報(bào)名啟動(dòng)!

    親愛(ài)的RT-Thread開(kāi)發(fā)者我們很高興地宣布,一年一度的RDC(RT-ThreadDeveloperConference,RT-Thread開(kāi)發(fā)者大會(huì))正式啟動(dòng)報(bào)名!2024RT-Threa
    的頭像 發(fā)表于 10-29 08:06 ?481次閱讀
    開(kāi)源共生 商業(yè)共贏 | <b class='flag-5'>RT-Thread</b> 2024開(kāi)發(fā)者大會(huì)報(bào)名啟動(dòng)!

    【大連】9月7日RT-Thread巡回線下培訓(xùn)-OpenMV機(jī)器視覺(jué)

    親愛(ài)的RT-Thread社區(qū)成員們:2024年RT-Thread全球開(kāi)發(fā)者線下培訓(xùn)拉開(kāi)帷幕啦!24年全球巡回培訓(xùn)將覆蓋超10座城市及國(guó)家,為開(kāi)發(fā)者提供一個(gè)深入學(xué)習(xí)RT-Thread嵌入
    的頭像 發(fā)表于 09-01 08:02 ?1788次閱讀
    【大連】9月7日<b class='flag-5'>RT-Thread</b>巡回線下培訓(xùn)-OpenMV機(jī)器視覺(jué)

    2024 RT-Thread全球巡回 線下培訓(xùn)火熱來(lái)襲!

    親愛(ài)的RT-Thread社區(qū)成員們:我們非常高興地宣布,2024年RT-Thread全球開(kāi)發(fā)者線下培訓(xùn)即將拉開(kāi)帷幕!24年全球巡回培訓(xùn)將覆蓋超10座城市及國(guó)家,為開(kāi)發(fā)者提供一個(gè)深入學(xué)習(xí)RT-T
    的頭像 發(fā)表于 08-07 08:35 ?1464次閱讀
    2024 <b class='flag-5'>RT-Thread</b>全球巡回 線下培訓(xùn)火熱來(lái)襲!

    RT-Thread 新里程碑達(dá)成——GitHub Star 破萬(wàn)!

    RT-Thread實(shí)時(shí)操作系統(tǒng)開(kāi)源項(xiàng)目在GitHub上的star數(shù)量突破一萬(wàn)!截止發(fā)文,RT-Thread作為實(shí)時(shí)操作系統(tǒng)在業(yè)界Star數(shù)量排名第一!倉(cāng)庫(kù)地址:https://github.com
    的頭像 發(fā)表于 07-04 08:35 ?512次閱讀
    <b class='flag-5'>RT-Thread</b> 新里程碑達(dá)成——GitHub Star 破萬(wàn)!

    6月6日杭州站RT-Thread線下workshop,探索RT-Thread混合部署新模式!

    6月6日下午我們將在杭州舉辦RT-Thread混合部署線下workshop,在瑞芯微RK3568平臺(tái)上實(shí)現(xiàn)同時(shí)運(yùn)行RT-Thread和linux,本次workshop邀請(qǐng)到RT-Thread資深
    的頭像 發(fā)表于 05-28 08:35 ?475次閱讀
    6月6日杭州站<b class='flag-5'>RT-Thread</b>線下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式!

    2024 RT-Thread 全球技術(shù)大會(huì)演講議程發(fā)布!

    RT-ThreadGlobalTechConference(RT-ThreadGTC,RT-Thread全球技術(shù)大會(huì))致力于圍繞RT-Thread基礎(chǔ)軟件技術(shù)發(fā)展、實(shí)踐創(chuàng)新、開(kāi)發(fā)者能力
    的頭像 發(fā)表于 05-16 08:34 ?606次閱讀
    2024 <b class='flag-5'>RT-Thread</b> 全球技術(shù)大會(huì)演講議程發(fā)布!

    新書(shū)發(fā)布——《實(shí)時(shí)操作系統(tǒng)應(yīng)用技術(shù):RT-Thread與ARM編程實(shí)踐》

    ——王宜懷的教授繼《嵌入式實(shí)時(shí)操作系統(tǒng)——基于RT-Thread的EAI&IoT系統(tǒng)開(kāi)發(fā)》之后的又一力作,不僅內(nèi)容豐富實(shí)用,而且講解方式深入淺出,適合不同層次的學(xué)習(xí)
    的頭像 發(fā)表于 05-11 08:35 ?864次閱讀
    新書(shū)發(fā)布——《實(shí)時(shí)操作系統(tǒng)應(yīng)用技術(shù):<b class='flag-5'>RT-Thread</b>與ARM編程實(shí)踐》

    5月16日南京站RT-Thread線下workshop,探索RT-Thread混合部署新模式!

    5月16日下午我們將在南京舉辦RT-Thread混合部署線下workshop,在瑞芯微RK3568平臺(tái)上實(shí)現(xiàn)同時(shí)運(yùn)行RT-Thread和linux,本次workshop邀請(qǐng)到RT-Thread資深
    的頭像 發(fā)表于 05-01 08:35 ?408次閱讀
    5月16日南京站<b class='flag-5'>RT-Thread</b>線下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式!

    RT-Thread混合部署Workshop北京站來(lái)啦!

    4月25日,下午我們將在北京舉辦RT-Thread混合部署線下workshop,在瑞芯微RK3568平臺(tái)上實(shí)現(xiàn)同時(shí)運(yùn)行RT-Thread和linux,本次workshop邀請(qǐng)到RT-Thread資深
    的頭像 發(fā)表于 04-19 08:34 ?469次閱讀
    <b class='flag-5'>RT-Thread</b>混合部署Workshop北京站來(lái)啦!

    4月25日北京站RT-Thread線下workshop,探索RT-Thread混合部署新模式

    4月25日,下午我們將在北京舉辦RT-Thread混合部署線下workshop,在瑞芯微RK3568平臺(tái)上實(shí)現(xiàn)同時(shí)運(yùn)行RT-Thread和linux,本次workshop邀請(qǐng)到RT-Thread資深
    的頭像 發(fā)表于 04-16 08:35 ?454次閱讀
    4月25日北京站<b class='flag-5'>RT-Thread</b>線下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式

    4月10日深圳場(chǎng)RT-Thread線下workshop,探索RT-Thread混合部署新模式!

    4月10日我們將在深圳福田舉辦RT-Thread混合部署線下workshop,在瑞芯微RK3568平臺(tái)上實(shí)現(xiàn)同時(shí)運(yùn)行RT-Thread和linux,本次workshop邀請(qǐng)到RT-Thread資深嵌入式軟件工程師農(nóng)曉明老師為您講
    的頭像 發(fā)表于 03-27 11:36 ?871次閱讀
    4月10日深圳場(chǎng)<b class='flag-5'>RT-Thread</b>線下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式!

    4月10日深圳場(chǎng)RT-Thread線下workshop,探索RT-Thread混合部署新模式!

    4月10日我們將在深圳福田舉辦RT-Thread混合部署線下workshop,在瑞芯微RK3568平臺(tái)上實(shí)現(xiàn)同時(shí)運(yùn)行RT-Thread和linux,本次workshop邀請(qǐng)到RT-Thread資深
    的頭像 發(fā)表于 03-27 08:34 ?562次閱讀
    4月10日深圳場(chǎng)<b class='flag-5'>RT-Thread</b>線下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式!

    恩智浦半導(dǎo)體正式加入RT-Thread全球合作伙伴計(jì)劃!

    前不久,恩智浦半導(dǎo)體正式加入RT-Thread全球合作伙伴計(jì)劃,成為RT-Thread高級(jí)會(huì)員合作伙伴。同時(shí),RT-Thread現(xiàn)已成為恩智浦注冊(cè)合作伙伴(RT-Thread| 簡(jiǎn)介合
    的頭像 發(fā)表于 03-14 10:40 ?663次閱讀
    恩智浦半導(dǎo)體正式加入<b class='flag-5'>RT-Thread</b>全球合作伙伴計(jì)劃!

    RT-Thread Studio中的RT-Thread Setting中已經(jīng)有軟件包管理和組件服務(wù)管理了,那還需要env工具嗎?

    RT-Thread Studio中的RT-Thread Setting中已經(jīng)有軟件包管理和組件服務(wù)管理了,那還需要env工具嗎,如果也使用env工具那不是和
    發(fā)表于 02-23 07:36