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

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

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

靜、動態(tài)內(nèi)存的優(yōu)劣比較

RTThread物聯(lián)網(wǎng)操作系統(tǒng) ? 來源:YXQ ? 2019-08-06 18:25 ? 次閱讀

關(guān)于靜態(tài)內(nèi)存與動態(tài)內(nèi)存

1.1、靜態(tài)和動態(tài)內(nèi)存的特點在探討這個問題之前我們先來對比下靜態(tài)內(nèi)存和動態(tài)內(nèi)存的特點:1. 創(chuàng)建的時間不同: 創(chuàng)建的時間不同:靜態(tài)分配發(fā)生在程序編譯和連接的時候。動態(tài)分配則發(fā)生在程序調(diào)入和執(zhí)行的時候。

編譯鏈接過程中已經(jīng)分配好的

代碼運行過程中使用rt_malloc分配

2. 創(chuàng)建的空間不同:堆都是動態(tài)分配的,沒有靜態(tài)分配的堆。棧有2種分配方式:靜態(tài)分配和動態(tài)分配。靜態(tài)分配是編譯器完成的,比如局部變量的分配。動態(tài)分配由函數(shù)malloc進(jìn)行分配。不過棧的動態(tài)分配和堆不同,他的動態(tài)分配是由編譯器進(jìn)行釋放,無需我們手工實現(xiàn)。

1.2、靜態(tài)和動態(tài)內(nèi)存的優(yōu)缺點

在了解了靜態(tài)內(nèi)存和動態(tài)內(nèi)存不同的特點后可以分析出它們在不同的方面具有不同的優(yōu)缺點:1.靜態(tài)內(nèi)存編譯階段就分配好了,不會存在分配失敗的情況,除非系統(tǒng)內(nèi)存被分配完了,但是在編譯階段就可以查出。動態(tài)內(nèi)存在運行中分配,在正常運行的情況下可能夠正常分配,在某種環(huán)境下可能分配失敗 ,這樣就對開發(fā)者的代碼水平要求更高,要求開發(fā)者需要對代碼的健壯性有要求。

2.靜態(tài)內(nèi)存由于是編譯階段分配好的,而動態(tài)內(nèi)存是由運行中分配,這樣動態(tài)內(nèi)存可以被高效復(fù)用,當(dāng)某段程序使用完畢后,可以將內(nèi)存交換給內(nèi)存池中等待下次程序的分配,由于這種機制,開發(fā)者可以利用更小的內(nèi)存開發(fā)更大型的程序。

3. 動態(tài)內(nèi)存由于是動態(tài)分配,所以涉及到分配和釋放的問題,假設(shè)X程序在分配了ABC3塊內(nèi)存,程序執(zhí)行完畢后AC區(qū)域內(nèi)存被釋放,但是由于開發(fā)者的疏忽導(dǎo)致B區(qū)域的內(nèi)存被遺留。而X程序又是會被反復(fù)調(diào)用的,這樣我們的內(nèi)存區(qū)域由于有沒有釋放的區(qū)域?qū)е旅看握{(diào)用就會占用一段區(qū)域,最終系統(tǒng)就沒有內(nèi)存可以使用。這種情況一般在產(chǎn)品實際體現(xiàn)為最開始的時候設(shè)備正常工作,但是運行了幾個小時或者幾天后死機。這種情況一般被稱作內(nèi)存泄漏(Memory Leak)。4. 在嵌入式RTOS中線程函數(shù)中使用靜態(tài)內(nèi)存,也就是在線程中定義局部變量,會加大線程??臻g的開銷。

裸機開發(fā)和RTOS開發(fā)的特點

1. 代碼規(guī)模:裸機開發(fā)的項目一般代碼規(guī)模度都比較小,對于一般開發(fā)者都難于駕馭使用裸機開發(fā)超大規(guī)模項目,人力成本和時間成本都太高。反而由于RTOS的模塊化特性,更容易開發(fā)出代碼規(guī)模大的項目。2. 系統(tǒng)穩(wěn)定性:在機電,航空,汽車等行業(yè)都是需要高實時性、高穩(wěn)定性和高安全性的。對于RTOS來說,系統(tǒng)任務(wù)的劃分調(diào)度都是系統(tǒng)管理,當(dāng)開發(fā)者對其機制了解不清楚的情況下反而帶來了部分風(fēng)險。除此之外RTOS上的內(nèi)存管理也是很大影響系統(tǒng)的,對于RTOS上一般不會存在MMU內(nèi)存管理單元,也就代表大部分運行RTOS的芯片上都沒有虛擬地址映射,那么就無法利用物理地址和虛擬地址的特性進(jìn)行內(nèi)存整理,避免內(nèi)存泄漏。所以說在RTOS動態(tài)內(nèi)存這塊內(nèi)存有風(fēng)險。

嵌入式中是否應(yīng)該使用動態(tài)內(nèi)存

明白不同內(nèi)存的優(yōu)缺點和裸機RTOS的特點之后,我們在回頭來分析 “嵌入式中是否應(yīng)該使用動態(tài)內(nèi)存?” 這個問題。在實時嵌入式系統(tǒng)中,由于系統(tǒng)軟件并不像PC上復(fù)雜,一般都是很簡單的內(nèi)存使用,所以一般也不使用動態(tài)內(nèi)存管理,但是隨著RTOS面臨的任務(wù)越來越重,尤其是IoTAIoT的到來,讓許多消費級產(chǎn)品運行的RTOS的負(fù)擔(dān)越來越重。在這種情況下繼續(xù)使用靜態(tài)內(nèi)存開發(fā)會極大的限制開發(fā)進(jìn)度,整個開發(fā)的靈活性非常低。同時靜態(tài)的內(nèi)存無法復(fù)用使用同一片內(nèi)存區(qū)域,相比與動態(tài)內(nèi)存在大型項目中一般會使用更多的內(nèi)存,在內(nèi)存大小不容樂觀的嵌入式系統(tǒng)是很難接受的。但是針對一些高穩(wěn)定性和高安全性的項目來說,使用動態(tài)內(nèi)存就需要好好斟酌下,由于RTOS上基本沒有MMU的硬件支持或者是系統(tǒng)軟件支持,所以不可避免的系統(tǒng)中會出現(xiàn)內(nèi)存碎片,從而有可能導(dǎo)致系統(tǒng)異常。

最終說了這么多總結(jié)成以下幾點:

1. 沒有使用RTOS的項目:不建議使用動態(tài)內(nèi)存,這種項目一般很簡單,不必使用動態(tài)內(nèi)存增大系統(tǒng)開銷和復(fù)雜度。

2. 使用RTOS的消費級項目:建議使用動態(tài)內(nèi)存,一般這種項目代碼復(fù)雜度比裸機高,合理使用動態(tài)內(nèi)存會有效降低內(nèi)存的開銷。同時很多Github項目的linux程序都是會使用內(nèi)存管理,有這套機制能更加方便的移植代碼。

3. 使用RTOS的軍工、航天、醫(yī)療等高穩(wěn)定性和高安全性項目:建議盡量降低對動態(tài)內(nèi)存的使用與依賴以確保系統(tǒng)的穩(wěn)定性。當(dāng)然也不代表動態(tài)內(nèi)存就無法在這些項目上使用,只是要求系統(tǒng)開發(fā)者對系統(tǒng)內(nèi)存的把控要求更高。

RT-Thread的內(nèi)存管理

RT-Thread 操作系統(tǒng)在內(nèi)存管理上,根據(jù)上層應(yīng)用及系統(tǒng)資源的不同,有針對性地提供了不同的內(nèi)存分配管理算法??傮w上可分為兩類:內(nèi)存堆管理與內(nèi)存池管理,而內(nèi)存堆管理又根據(jù)具體內(nèi)存設(shè)備劃分為三種情況:

第一種是針對小內(nèi)存塊的分配管理(小內(nèi)存管理算法);第二種是針對大內(nèi)存塊的分配管理(slab 管理算法);第三種是針對多內(nèi)存堆的分配情況(memheap 管理算法)。

小內(nèi)存管理算法是一個簡單的內(nèi)存分配算法。初始時,它是一塊大的內(nèi)存。當(dāng)需要分配內(nèi)存塊時,將從這個大的內(nèi)存塊上分割出相匹配的內(nèi)存塊,然后把分割出來的空閑內(nèi)存塊還回給堆管理系統(tǒng)中。每個內(nèi)存塊都包含一個管理用的數(shù)據(jù)頭,通過這個頭把使用塊與空閑塊用雙向鏈表的方式鏈接起來。

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

原文標(biāo)題:嵌入式中是否應(yīng)該使用動態(tài)內(nèi)存?

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

收藏 人收藏

    評論

    相關(guān)推薦

    串聯(lián)電路與并聯(lián)電路的優(yōu)劣比較

    串聯(lián)電路與并聯(lián)電路各有其優(yōu)劣,具體如下: 串聯(lián)電路的優(yōu)勢: 電流相同:串聯(lián)電路中,流過每個元件的電流是相同的,這使得在需要控制電流的應(yīng)用中很有用。 簡化電路設(shè)計:在某些情況下,串聯(lián)電路的設(shè)計和實現(xiàn)
    的頭像 發(fā)表于 12-02 17:32 ?697次閱讀

    Prolith和HyperLith的優(yōu)劣

    Prolith和HyperLith在光刻領(lǐng)域的優(yōu)劣勢,可以展開討論討論
    發(fā)表于 11-29 22:12

    DDR內(nèi)存與SDRAM的區(qū)別 DDR4內(nèi)存與DDR3內(nèi)存哪個好

    DDR內(nèi)存與SDRAM的區(qū)別 1. 定義與起源 SDRAM (Synchronous Dynamic Random Access Memory) :同步動態(tài)隨機存取存儲器,是一種早期的內(nèi)存技術(shù),它與
    的頭像 發(fā)表于 11-29 14:57 ?506次閱讀

    DDR內(nèi)存的工作原理與結(jié)構(gòu)

    DDR內(nèi)存,全稱為Double Data Rate Synchronous Dynamic Random Access Memory(雙倍數(shù)據(jù)速率同步動態(tài)隨機存取內(nèi)存),是一種用于計算機和其他
    的頭像 發(fā)表于 11-20 14:32 ?499次閱讀

    Linux內(nèi)存泄露案例分析和內(nèi)存管理分享

    內(nèi)存報警的消息,讓整個團(tuán)隊都比較緊張,我們團(tuán)隊負(fù)責(zé)的LB服務(wù)是零售、物流、科技等業(yè)務(wù)服務(wù)的流量入口,承接上萬個服務(wù)的流量轉(zhuǎn)發(fā),一旦有故障影響業(yè)務(wù)服務(wù)比較多,必須馬上著手解決內(nèi)存暴漲的問
    的頭像 發(fā)表于 10-24 16:14 ?741次閱讀
    Linux<b class='flag-5'>內(nèi)存</b>泄露案例分析和<b class='flag-5'>內(nèi)存</b>管理分享

    如何評判電子煙PCBA方案優(yōu)劣

    如何評判電子煙方案優(yōu)劣
    的頭像 發(fā)表于 10-16 16:21 ?557次閱讀
    如何評判電子煙PCBA方案<b class='flag-5'>優(yōu)劣</b>

    內(nèi)存時鐘和內(nèi)存條有什么不同

    在探討內(nèi)存時鐘(Memory Clock)和內(nèi)存條(Memory Module)的不同時,我們首先需要明確這兩個概念的基本定義和它們在計算機系統(tǒng)中的角色。以下是對這兩個概念的詳細(xì)解析,以及它們之間差異的比較
    的頭像 發(fā)表于 09-04 11:45 ?1502次閱讀

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

    策略都有其特定的使用場景和優(yōu)缺點。以下是一些步驟和建議,用于自定義內(nèi)存控制器的設(shè)置: 1. 選擇合適的內(nèi)存分配策略 heap_1 :最簡單的內(nèi)存分配策略,但分配的內(nèi)存不允許釋放。適用于
    的頭像 發(fā)表于 09-02 14:28 ?501次閱讀

    單片機中的幾種環(huán)形緩沖區(qū)的分析和實現(xiàn)

    問題,而且其能夠更高效的使用內(nèi)存。在單片機中,由于內(nèi)存有限,而且需要盡可能避免使用動態(tài)內(nèi)存,所以環(huán)形緩沖區(qū)在單片機中應(yīng)用非常廣泛。二、原理通常我們需要使用一個數(shù)組
    的頭像 發(fā)表于 08-14 08:39 ?889次閱讀
    單片機中的幾種環(huán)形緩沖區(qū)的分析和實現(xiàn)

    你知道嗎? 51單片機也有動態(tài)內(nèi)存分配

    一、簡述其實在51單片機中也可以使用動態(tài)內(nèi)存動態(tài)內(nèi)存其實就是劃出一塊內(nèi)存區(qū)域,將這塊內(nèi)存進(jìn)行管理,稱為內(nèi)存管理。51單片機可以使用c語言自
    的頭像 發(fā)表于 04-26 08:10 ?1568次閱讀
    你知道嗎? 51單片機也有<b class='flag-5'>動態(tài)內(nèi)存</b>分配

    電池模組需要置嗎?為什么?

    電池模組在生產(chǎn)過程中確實需要進(jìn)行置處理,這一步驟對于電池的性能和安全性至關(guān)重要。
    的頭像 發(fā)表于 04-12 16:47 ?1413次閱讀

    探索推理時KV Cache的動態(tài)內(nèi)存壓縮方法

    DMC通過一個決策變量(α)來有效地對輸入序列進(jìn)行分段,每個段落可以獨立地決定是繼續(xù)追加還是進(jìn)行累積。這允許模型在不同段落之間動態(tài)調(diào)整內(nèi)存使用。
    發(fā)表于 03-22 09:16 ?907次閱讀
    探索推理時KV Cache的<b class='flag-5'>動態(tài)內(nèi)存</b>壓縮方法

    C語言的指針用法

    C語言編程中善用指針可以簡化一些任務(wù)的處理,而對于一些任務(wù)(比如動態(tài)內(nèi)存分配),必須要有指針才行的。也就是說精通C指針編程是很有必要的,幫助你成為一名優(yōu)秀的Cer。
    發(fā)表于 03-05 14:22 ?359次閱讀
    C語言的指針用法

    C語言中的動態(tài)內(nèi)存管理講解

    本章將講解 C 中的動態(tài)內(nèi)存管理。C 語言為內(nèi)存的分配和管理提供了幾個函數(shù)。這些函數(shù)可以在 頭文件中找到。
    的頭像 發(fā)表于 02-23 14:03 ?398次閱讀
    C語言中的<b class='flag-5'>動態(tài)內(nèi)存</b>管理講解

    單片機上用malloc()是個坑,有隱患?

    做單片機研發(fā)前幾年,一直沒用過動態(tài)內(nèi)存分配的功能,但是如果想成為軟件架構(gòu)設(shè)計師,這是繞不過的一道坎。
    的頭像 發(fā)表于 02-22 15:53 ?2264次閱讀
    單片機上用malloc()是個坑,有隱患?