99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

電子發(fā)燒友App

硬聲App

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

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

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>嵌入式開(kāi)發(fā)>Buddy算法在μC/OSII動(dòng)態(tài)內(nèi)存管理改進(jìn)中的應(yīng)用分析

Buddy算法在μC/OSII動(dòng)態(tài)內(nèi)存管理改進(jìn)中的應(yīng)用分析

2017-10-26 | rar | 0.4 MB | 次下載 | 1積分

資料介紹

1 內(nèi)存管理概述
  內(nèi)存管理是操作系統(tǒng)中心任務(wù)之一,其主要任務(wù)是組織內(nèi)存以容納內(nèi)核和待執(zhí)行程序,跟蹤當(dāng)前內(nèi)存的使用情況,在需要時(shí)為進(jìn)程分配內(nèi)存,使用完畢后釋放并回收內(nèi)存。目前嵌入式系統(tǒng)中常用的內(nèi)存管理策略主要有兩種--靜態(tài)內(nèi)存分配和動(dòng)態(tài)內(nèi)存分配。
  靜態(tài)內(nèi)存分配: 編譯或鏈接時(shí)將所需內(nèi)存分配好,程序運(yùn)行起來(lái)后所分配的內(nèi)存不釋放。對(duì)于實(shí)時(shí)性和可靠性要求極高的系統(tǒng),不允許延遲或者分配失效,必須采用靜態(tài)內(nèi)存分配的方式。
  動(dòng)態(tài)內(nèi)存分配: 根據(jù)程序執(zhí)行過(guò)程中所需內(nèi)存的大小而動(dòng)態(tài)分配內(nèi)存的策略。此方案按需分配內(nèi)存,避免了靜態(tài)分配中的內(nèi)存浪費(fèi),靈活性比較強(qiáng),給程序的實(shí)現(xiàn)帶來(lái)了很大方便。缺點(diǎn)是容易造成內(nèi)存碎片,且容易造成程序響應(yīng)不及時(shí)等問(wèn)題。
  綜上所述,靜態(tài)內(nèi)存分配和動(dòng)態(tài)內(nèi)存分配各有優(yōu)點(diǎn),出于嵌入式系統(tǒng)可靠性、實(shí)時(shí)性及成本、功耗的考慮,如何在兩種方案中作出平衡的選擇是令嵌入式操作系統(tǒng)設(shè)計(jì)者頭疼的事。一般的嵌入式操作系統(tǒng)都是兩種方案的高效結(jié)合,μC/OSII也不例外。除此之外,嵌入式操作系統(tǒng)對(duì)內(nèi)存的分配還有以下幾點(diǎn)要求:
 ?、?可靠性。內(nèi)存分配的請(qǐng)求必須得到滿(mǎn)足,如果分配失敗可能會(huì)帶來(lái)災(zāi)難性的后果。比如,航天飛機(jī)的嵌入式操作系統(tǒng)若發(fā)生內(nèi)存分配失效,損失是不可估量的。
 ?、?快速性。嵌入式系統(tǒng)對(duì)實(shí)時(shí)性的保證,要求簡(jiǎn)單、快速地分配內(nèi)存。
 ?、?高效性。嵌入式系統(tǒng)中內(nèi)存是一種有限、昂貴的資源,內(nèi)存分配要盡可能地減少浪費(fèi)。
  μC/OSII作為一種典型的嵌入式操作系統(tǒng),其內(nèi)存管理同樣要滿(mǎn)足以上3點(diǎn)要求,下面簡(jiǎn)單介紹μC/OSII的內(nèi)存管理策略,并分析其不足之處。
  2 μC/OSII動(dòng)態(tài)內(nèi)存管理方案及不足
  2.1 μC/OSII內(nèi)存管理方案簡(jiǎn)介
  μC/OSII內(nèi)存管理模塊主要由一個(gè)數(shù)據(jù)結(jié)構(gòu)體和5個(gè)函數(shù)組成:
  ◆ 內(nèi)存控制塊數(shù)據(jù)結(jié)構(gòu)OS_MEM;
  ◆ 內(nèi)存分區(qū)創(chuàng)建函數(shù)OSMemCreate(void *addr, INT32U nblks, INT32U blksize, INT8U *err);
  ◆ 內(nèi)存塊分配函數(shù)OSMemGet(OS_MEM *pmem , INT8U *err);
  ◆ 內(nèi)存塊釋放函數(shù)OSMemPut(OS_MEM *pmem , void *pblk);
  ◆ 內(nèi)存分區(qū)狀態(tài)查詢(xún)函數(shù)OSMemQuery(OS_MEM *pmem, OS_MEM_DATA *p_mem_data);
  ◆ 內(nèi)存控制塊鏈表初始化函數(shù)OSMemInit(void)。
  μC/OSII用一個(gè)內(nèi)存控制塊(OS_MEM)來(lái)管理內(nèi)存分區(qū),主要通過(guò)以下4步來(lái)管理:
 ?、?內(nèi)存控制塊鏈表初始化函數(shù)OSMemInit()負(fù)責(zé)創(chuàng)建空內(nèi)存控制塊結(jié)構(gòu)的鏈表,鏈表長(zhǎng)度由內(nèi)核OS_CFG.H文件中定義的OS_MAX_MEM_PART宏確定。
 ?、?內(nèi)存塊創(chuàng)建函數(shù)OSMemCreate()先從空內(nèi)存控制塊結(jié)構(gòu)鏈表上獲取一個(gè)空的內(nèi)存控制根塊結(jié)構(gòu),根據(jù)用戶(hù)需要內(nèi)存塊的大小來(lái)創(chuàng)建分區(qū)。一個(gè)分區(qū)中含有相同大小的內(nèi)存塊,各內(nèi)存塊也是通過(guò)鏈表鏈接起來(lái),而不同分區(qū)中的內(nèi)存塊大小一般不同,如圖1所示的PartitiON # 1和Partition # 2中內(nèi)存塊的大小是不同的。
  Buddy算法在μC/OSII動(dòng)態(tài)內(nèi)存管理改進(jìn)中的應(yīng)用分析
  圖1 μC/OSII通過(guò)內(nèi)存控制塊管理內(nèi)存
 ?、?內(nèi)存塊分配函數(shù)OSMemGet()通過(guò)從內(nèi)存控制塊鏈表中找到能夠滿(mǎn)足自己內(nèi)存塊需要的內(nèi)存控制塊,然后從這個(gè)內(nèi)存控制塊指向的分區(qū)鏈表首部得到自己需要的內(nèi)存塊。
  ④ 內(nèi)存塊釋放函數(shù)OSMemPut()負(fù)責(zé)回收內(nèi)存塊。當(dāng)應(yīng)用程序不再使用某一個(gè)內(nèi)存塊時(shí),必須及時(shí)把它釋放,并放回到相應(yīng)的內(nèi)存分區(qū)中。
  2.2 μC/OSII內(nèi)存管理方案的不足之處
  如前所述,μC/OSII的內(nèi)存管理方案簡(jiǎn)短精煉,僅百余行代碼,5個(gè)函數(shù)就能勝任。然而考慮到第1節(jié)提到的嵌入式系統(tǒng)對(duì)內(nèi)存管理策略的3個(gè)要求,μC/OSII的內(nèi)存管理策略存在以下不足之處:
 ?、?原μC/OSII內(nèi)存管理方案可靠性不高。因?yàn)樵桨钢懈鲀?nèi)存分區(qū)之間是孤立的,沒(méi)有聯(lián)系。一個(gè)內(nèi)存分區(qū)上的內(nèi)存塊用完時(shí),不能利用其他分區(qū)上的內(nèi)存塊,而只是簡(jiǎn)單地報(bào)錯(cuò),從而使系統(tǒng)可靠性大大降低。在內(nèi)存塊大小及需求量不確定的場(chǎng)合,如果經(jīng)常發(fā)生內(nèi)存申請(qǐng)得不到滿(mǎn)足的情況,是嵌入式系統(tǒng)所不能容忍的。
  ② 原μC/OSII內(nèi)存管理方案中內(nèi)存分配不夠靈活。舉個(gè)例子來(lái)說(shuō),一個(gè)應(yīng)用程序需要大小為1 KB、512 B、256 B三種內(nèi)存塊,原方案有兩種解決方案,一是創(chuàng)建一個(gè)內(nèi)存塊大小為1 KB的內(nèi)存分區(qū),內(nèi)存塊數(shù)目至少為3個(gè);二是創(chuàng)建3個(gè)內(nèi)存分區(qū),內(nèi)存塊大小分別為1 KB、512 B、256 B。方案一創(chuàng)建了較少分區(qū),性能有保證,但造成內(nèi)存資源的浪費(fèi);方案二雖然沒(méi)有浪費(fèi)內(nèi)存,但卻調(diào)用3次OS_MemCreate()函數(shù),效率較低。
下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評(píng)論

查看更多

下載排行

本周

  1. 1TC358743XBG評(píng)估板參考手冊(cè)
  2. 1.36 MB  |  330次下載  |  免費(fèi)
  3. 2開(kāi)關(guān)電源基礎(chǔ)知識(shí)
  4. 5.73 MB  |  6次下載  |  免費(fèi)
  5. 3100W短波放大電路圖
  6. 0.05 MB  |  4次下載  |  3 積分
  7. 4嵌入式linux-聊天程序設(shè)計(jì)
  8. 0.60 MB  |  3次下載  |  免費(fèi)
  9. 5基于FPGA的光纖通信系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn)
  10. 0.61 MB  |  2次下載  |  免費(fèi)
  11. 6基于FPGA的C8051F單片機(jī)開(kāi)發(fā)板設(shè)計(jì)
  12. 0.70 MB  |  2次下載  |  免費(fèi)
  13. 751單片機(jī)窗簾控制器仿真程序
  14. 1.93 MB  |  2次下載  |  免費(fèi)
  15. 8基于51單片機(jī)的RGB調(diào)色燈程序仿真
  16. 0.86 MB  |  2次下載  |  免費(fèi)

本月

  1. 1OrCAD10.5下載OrCAD10.5中文版軟件
  2. 0.00 MB  |  234315次下載  |  免費(fèi)
  3. 2555集成電路應(yīng)用800例(新編版)
  4. 0.00 MB  |  33564次下載  |  免費(fèi)
  5. 3接口電路圖大全
  6. 未知  |  30323次下載  |  免費(fèi)
  7. 4開(kāi)關(guān)電源設(shè)計(jì)實(shí)例指南
  8. 未知  |  21548次下載  |  免費(fèi)
  9. 5電氣工程師手冊(cè)免費(fèi)下載(新編第二版pdf電子書(shū))
  10. 0.00 MB  |  15349次下載  |  免費(fèi)
  11. 6數(shù)字電路基礎(chǔ)pdf(下載)
  12. 未知  |  13750次下載  |  免費(fèi)
  13. 7電子制作實(shí)例集錦 下載
  14. 未知  |  8113次下載  |  免費(fèi)
  15. 8《LED驅(qū)動(dòng)電路設(shè)計(jì)》 溫德?tīng)栔?/a>
  16. 0.00 MB  |  6653次下載  |  免費(fèi)

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935054次下載  |  免費(fèi)
  3. 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
  4. 78.1 MB  |  537796次下載  |  免費(fèi)
  5. 3MATLAB 7.1 下載 (含軟件介紹)
  6. 未知  |  420026次下載  |  免費(fèi)
  7. 4OrCAD10.5下載OrCAD10.5中文版軟件
  8. 0.00 MB  |  234315次下載  |  免費(fèi)
  9. 5Altium DXP2002下載入口
  10. 未知  |  233046次下載  |  免費(fèi)
  11. 6電路仿真軟件multisim 10.0免費(fèi)下載
  12. 340992  |  191185次下載  |  免費(fèi)
  13. 7十天學(xué)會(huì)AVR單片機(jī)與C語(yǔ)言視頻教程 下載
  14. 158M  |  183278次下載  |  免費(fèi)
  15. 8proe5.0野火版下載(中文版免費(fèi)下載)
  16. 未知  |  138040次下載  |  免費(fèi)