版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、12(6068a)《KeilC動態(tài)內(nèi)存管理機制分析及改進※》P74全文如下:KeilC動態(tài)內(nèi)存管理機制分析及改進丁明亮丁明亮熊真春熊真春[摘要摘要]通過對C51中init_mempoolmallocfree三個函數(shù)源代碼的分析,深入分析C51的動態(tài)內(nèi)存管理機制,同時也給出一些使init_mempool函數(shù)更完善和除去free函數(shù)中的一個錯誤的建議。[關(guān)鍵詞關(guān)鍵詞]C51動態(tài)內(nèi)存管理動態(tài)內(nèi)存管理分析分析Abstract:basedonth
2、eanalysistosourcesoffunctioninit_mempoolmallocfreethisarticleprobesthedynamicmemymanagementofC51Librarygivesoutsomeadvicestobetterfunctioninit_mempooltoclearabugoffunctionfree.Keywds:C51dynamicmemymanagement37.5A庫中init_m
3、em.c的源代碼如下所示。#defineHLEN(sizeof(__memt__))#defineMIN_POOL_SIZE(HLEN10)intinit_mempool(void_MALLOC_MEM_poolunsignedintsize)if(sizenext=NULL(AVAIL.next)len=sizeHLENreturn(1)成功堆NULLsizeHLEN…AVAILpoolsize圖1:init_mempool執(zhí)行后的執(zhí)
4、行后的AVAIL鏈表及堆空間鏈表及堆空間在成功執(zhí)行init_mempool函數(shù)后,將得到如圖1所示的一個數(shù)據(jù)結(jié)構(gòu)。另外,鏈?zhǔn)捉Y(jié)點AVAIL的len域記錄了整個堆的字節(jié)數(shù)。鏈?zhǔn)譇VAIL結(jié)點的next域指向的是首塊空閑塊,當(dāng)經(jīng)過多次的malloc函數(shù)而堆中沒有空閑內(nèi)存塊時,AVAIL結(jié)點的next域?qū)镹ULL值。很明顯,從上面的if(pool==NULL)pool=1size這部分源代碼來看,如果應(yīng)用程序中pool參數(shù)為空指針(pool
5、為0)時,此時顯然不能直接將AVAIL的next域的值賦為空指針的(即賦為0),于是便將pool的值改為1,再將size的值減1,這樣,init_mempool函數(shù)會在XDATA區(qū)中,從地址1開始,取size1個字節(jié)來作為堆來使用,如果源程序有定義在XDATA區(qū)的變量,則這些變量所占的存儲單元也可能會被當(dāng)成堆空間的一部分,這無疑是有潛在風(fēng)險的。部分程序員在調(diào)用init_mempool函數(shù)時習(xí)慣將pool參數(shù)設(shè)為一個形如0xAAAA數(shù)字表
6、示的絕對地址,如果不加特別防范,也是不妥的,因為KeilC可能會在你以如此方式指定的堆空間中分配臨時變量。好的習(xí)慣是定義一個字節(jié)數(shù)組作為堆空間,再將數(shù)組名作為pool參數(shù)調(diào)用init_mempool函數(shù)。在KeilC的聯(lián)機文檔中,指明了init_mempool在應(yīng)用程序中只能被調(diào)用一次,那么,如果多次調(diào)用該函數(shù)又會有什么后果呢?從該函數(shù)的源代碼來分析,多次調(diào)用init_mempool函數(shù)會導(dǎo)致重新初始化首結(jié)點AVAIL的next域和le
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- Linux內(nèi)核中動態(tài)內(nèi)存檢測機制的研究.pdf
- 動態(tài)存儲管理機制的改進及實現(xiàn).pdf
- 基于內(nèi)存熱插拔的虛擬機動態(tài)內(nèi)存管理系統(tǒng).pdf
- Linux進程和內(nèi)存管理機制的分析及研究.pdf
- 基于預(yù)拷貝改進技術(shù)的虛擬機動態(tài)內(nèi)存遷移研究.pdf
- 實時嵌入式操作系統(tǒng)動態(tài)內(nèi)存管理研究.pdf
- 面向新型混合內(nèi)存架構(gòu)的內(nèi)存管理機制.pdf
- 并發(fā)數(shù)據(jù)結(jié)構(gòu)及其在動態(tài)內(nèi)存管理中的應(yīng)用.pdf
- 嵌入式實時系統(tǒng)ARTs-OS的動態(tài)內(nèi)存管理研究.pdf
- Android虛擬機內(nèi)存管理機制的分析及性能優(yōu)化.pdf
- Dalvik虛擬機內(nèi)存管理機制分析與優(yōu)化.pdf
- 面向嵌入式實時系統(tǒng)的動態(tài)內(nèi)存管理方法研究.pdf
- 嵌入式實時操作系統(tǒng)動態(tài)內(nèi)存管理優(yōu)化方案的研究.pdf
- 嵌入式實時系統(tǒng)動態(tài)內(nèi)存分配管理器的設(shè)計與實現(xiàn).pdf
- 可控動態(tài)內(nèi)存分配器的研究與開發(fā).pdf
- 面向Cassandra的內(nèi)存管理機制研究與實現(xiàn).pdf
- 異構(gòu)內(nèi)存環(huán)境下的系統(tǒng)狀態(tài)管理機制.pdf
- 基于bank劃分的異構(gòu)內(nèi)存訪存管理機制
- 基于SEP6200的動態(tài)內(nèi)存分配方法設(shè)計.pdf
- RTOS中內(nèi)存管理機制的設(shè)計與實現(xiàn).pdf
評論
0/150
提交評論