電子產(chǎn)業(yè)一站式賦能平臺

PCB聯(lián)盟網(wǎng)

搜索
查看: 2485|回復: 0
收起左側(cè)

嵌入式教程視頻教程_嵌入式實時系統(tǒng)的動態(tài)內(nèi)存

[復制鏈接]

2607

主題

2607

帖子

7472

積分

高級會員

Rank: 5Rank: 5

積分
7472
跳轉(zhuǎn)到指定樓層
樓主
發(fā)表于 2020-8-20 17:29:41 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
嵌入式教程視頻教程_嵌入式實時系統(tǒng)的動態(tài)內(nèi)存,嵌入式入門級視頻, 嵌入式入門教程視頻, 嵌入式入門看誰的視頻, 嵌入式入門看誰的視頻教程, 嵌入式入門免費視頻, 嵌入式入門視頻百度云, 嵌入式入門視頻教程, 嵌入式入門視頻教程網(wǎng)盤, 嵌入式入門視頻教程下載, 嵌入式入門視頻免費, 嵌入式入門視頻網(wǎng)站, 嵌入式入門誰的視頻最合適, 嵌入式軟件c視頻, 嵌入式軟件c視頻教程, 嵌入式軟件linux視頻, 嵌入式軟件編程視頻, 嵌入式軟件測試視頻, 嵌入式軟件測試視頻教程, 嵌入式軟件測試視頻下載, 嵌入式軟件工程師視頻, 嵌入式軟件工程師視頻百度云,   

  

進入20世紀90年代,嵌入式技術(shù)全面展開,目前已成為通信和消費類產(chǎn)品的共同發(fā)展方向。在通信領(lǐng)域,數(shù)字技術(shù)正在全面取代模擬技術(shù)。在廣播電視領(lǐng)域,美國已開始由模擬電視向數(shù)字電視轉(zhuǎn)變,歐洲的DVB(數(shù)字電視廣播)技術(shù)已在全球大多數(shù)國家推廣。數(shù)字音頻廣播(DAB)也已進入商品化試播階段。而軟件、集成電路和新型元器件在產(chǎn)業(yè)發(fā)展中的作用日益重要。

動態(tài)內(nèi)存管理的基本任務(wù)就是有效地對動態(tài)內(nèi)存進行分配、回收,并同時保證系統(tǒng)的快速性、可靠性和穩(wěn)定性。當系統(tǒng)請求分配內(nèi)存時,系統(tǒng)需要從所有空閑塊中找到一個合適的空閑塊進行分配;當用戶不再使用而將某塊內(nèi)存釋放時,系統(tǒng)需要回收這一內(nèi)存塊,以備在新的請求產(chǎn)生時重新進行分配。為此,系統(tǒng)需要建立一個與內(nèi)存當前使用情況相對應的內(nèi)存描述,用來記錄所有與內(nèi)存分配、回收相關(guān)的信息。而如何記錄這些信息并進行分配與回收,便成為各種算法的最根本區(qū)別。

1 嵌入式系統(tǒng)中內(nèi)存管理技術(shù)的特點

實時系統(tǒng)分為硬實時系統(tǒng)和軟實時系統(tǒng)。硬實時系統(tǒng)是指系統(tǒng)中各任務(wù)不僅要執(zhí)行無誤而且要做到準時;軟實時系統(tǒng)是指系統(tǒng)中各任務(wù)運行的越快越好,并不要求限定某一任務(wù)必須在多長時間內(nèi)完成?梢钥闯鰟討B(tài)內(nèi)存分配是絕對不能用于硬實時系統(tǒng)的,因為動態(tài)分配具有時間不確定性(分配時間與內(nèi)存塊數(shù)量有關(guān)),而且動態(tài)分配可能產(chǎn)生分配不成功的情況。所以對于硬實時系統(tǒng),只能采用靜態(tài)內(nèi)存分配方式。靜態(tài)分配是指在編譯或鏈接時將程序所需的內(nèi)存空間分配好,這樣不會出現(xiàn)分配失敗的情況。

1.1 靜態(tài)分配與動態(tài)分配

靜態(tài)分配為系統(tǒng)提供了最好的可靠性與實時性。對于那些對實時性和可靠性要求極高的需求,就只能采用靜態(tài)分配方式。但采用靜態(tài)分配就必然會使系統(tǒng)失去靈活性。因此必須在設(shè)計階段考慮所有可能的情況,并對所有的需求做出相應的空間分配。一旦出現(xiàn)沒有考慮到的情況,系統(tǒng)就無法處理。此外靜態(tài)分配方式也必然導致很大的浪費,因為必須按照最壞情況進行最大的配置,而在實際運行中可能只用到其中的一小部分。

動態(tài)分配為系統(tǒng)提供了很大的靈活性,而且在內(nèi)存的利用率和系統(tǒng)功能擴展等方面也都明顯地優(yōu)于靜態(tài)分配。

大多數(shù)系統(tǒng)采用靜態(tài)分配和動態(tài)分配相結(jié)合的方式。由于嵌入式系統(tǒng)本身各個任務(wù)的可靠性、實時性要求不盡相同,通常會有一部分任務(wù)對可靠性與實時性沒有特別嚴格的要求。這些任務(wù)對一定的延時與失敗是可以接受的。因此對于這樣的一部分任務(wù),就可以采用動態(tài)分配方式來滿足它們部分或全部的內(nèi)存需求。而對于那些有嚴格時限要求的任務(wù),為了保證任務(wù)的可靠性和實時性,就應采用靜態(tài)分配方式。

1.2 動態(tài)分配的技術(shù)要求

(1)快速性:由于嵌入式系統(tǒng)對實時性要求較高,所以內(nèi)存分配過程要盡可能地快。在嵌入式系統(tǒng)中,由于還不能采用通用操作系統(tǒng)中復雜而完善的內(nèi)存分配策略,所以一般都采用簡單、快速的內(nèi)存分配方案。

(2)可靠性:由于嵌入式系統(tǒng)對可靠性的要求較高,所以內(nèi)存分配過程也要具備高可靠性。但由于各個嵌入式系統(tǒng)之間對可靠性的要求不盡相同,對內(nèi)存分配的可靠性要求也就各不相同。通常,可靠性要求極高的系統(tǒng)不采用動態(tài)分配。

(3)高效性:由于在嵌入式系統(tǒng)中內(nèi)存資源都相對有限,所以為了保證程序的正常運行,內(nèi)存管理系統(tǒng)要盡可能高效地使用內(nèi)存,減少不必要的浪費。

2 伙伴系統(tǒng)

2.1 伙伴系統(tǒng)原理

伙伴(buddy)系統(tǒng)的基本原理就是按照2的冪次方大小對內(nèi)存進行分配,以此得到很高的分配速度和回收速度。例如:對于10KB的空間請求,伙伴系統(tǒng)會分配16KB的空間來滿足。因為內(nèi)存空閑塊大小均為2的冪次方,所以需要16KB,這是滿足10KB的最小空間;同樣對于70KB的空間請求,伙伴系統(tǒng)會分配128KB的空間來滿足。

2.2 伙伴系統(tǒng)存在的問題

伙伴系統(tǒng)比那些按大小而不按塊的整數(shù)倍地址分配的算法有更多的優(yōu)點。其優(yōu)點為當一個大小為2的K次冪的塊被釋放后,存儲管理只需要搜索2的K次冪字節(jié)大小的塊以判定是否需要合并。那些允許內(nèi)存塊以任意形式分割的策略需要搜索所有的空閑塊表。相比之下,伙伴系統(tǒng)更快。

但是對于內(nèi)存利用率來說,伙伴系統(tǒng)是極其低效的。問題出自所有的內(nèi)存請求都必須以2的冪次方大小的空間來滿足,一個35KB的請求需要分配64KB的空間,其余的29KB被浪費了。在極端情況下內(nèi)存資源有近50%被浪費。

3 連續(xù)的內(nèi)存分配

3.1 問題提出

伙伴系統(tǒng)的內(nèi)存管理方式對空間的使用存在極大的浪費。在某些情況下還會由于資源的浪費,導致后繼的內(nèi)存請求得不到滿足,進而嚴重地影響程序的正常功能。

試考慮:系統(tǒng)共有1MB內(nèi)存空間可用,采用伙伴系統(tǒng)進行管理。有如下請求:請求A,300KB;請求B,300KB;請求C,50KB.結(jié)果如表1所示。

由表1中可以看出:伙伴系統(tǒng)對空間的浪費是極其嚴重的,即使在物理內(nèi)存充足(1MB)的情況下,也會產(chǎn)生請求(650KB)無法滿足的情況。

由于在嵌入式系統(tǒng)中,一般都沒有虛擬內(nèi)存的支持,所以當內(nèi)存請求無法得到滿足時,將嚴重影響程序的正常功能。因此為了保證程序的正常功能,就要提高內(nèi)存的利用率,盡可能地滿足程序的內(nèi)存請求。所以在對伙伴系統(tǒng)進行分析的基礎(chǔ)上,提出了連續(xù)的內(nèi)存分配方式。
回復

使用道具 舉報

發(fā)表回復

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

關(guān)閉

站長推薦上一條 /1 下一條


聯(lián)系客服 關(guān)注微信 下載APP 返回頂部 返回列表