版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
第第頁使用C語言實(shí)現(xiàn)簡單動態(tài)內(nèi)存分配1前言
首先要明白為何需要動態(tài)內(nèi)存分配,熟悉(C語言)的讀者應(yīng)該對這個比較熟悉,需要一段內(nèi)存時會使用malloc函數(shù)來申請所需要大小的內(nèi)存,函數(shù)返回一段內(nèi)存的首地址。
簡單來說,動態(tài)內(nèi)存分配的好處在于需要內(nèi)存的時候可以按需分配,當(dāng)不需要內(nèi)存的時候可以將其釋放掉,這樣可以高效的利用內(nèi)存。下面本文從零開始實(shí)現(xiàn)一個完整的動態(tài)內(nèi)存分配。
2簡單動態(tài)內(nèi)存分配實(shí)現(xiàn)
內(nèi)存分配是將沒有使用的內(nèi)存塊給需要的變量(普通變量、指針變量、結(jié)構(gòu)體變量等等)使用,由于其使用后需要進(jìn)行釋放,這就會導(dǎo)致空閑的內(nèi)存是分散在內(nèi)存池中的。因此,必須要對內(nèi)存進(jìn)行管理,也就是對內(nèi)存的使用情況做標(biāo)記。
上圖是一個內(nèi)存池使用后的某一時刻,可以看到,使用的塊和沒有使用的塊并不是連續(xù)的,這樣就需要用一個表對其進(jìn)行標(biāo)記,這個表稱為BitMap。假設(shè)現(xiàn)在將內(nèi)存按照每個By(te)進(jìn)行劃分,然后用一個bit對塊進(jìn)行標(biāo)記,1表示已使用,0表示沒有使用,這樣一個塊需要一個bit。
下面來用C語言來實(shí)現(xiàn)這個簡單的動態(tài)內(nèi)存分配。
最終終端輸出結(jié)果如下:
上面已經(jīng)實(shí)現(xiàn)了一個簡單的動態(tài)內(nèi)存分配,可以完成內(nèi)存的分配和釋放以及輸出使用率和查看位圖。這種方式實(shí)現(xiàn)的動態(tài)內(nèi)存分配不會產(chǎn)生內(nèi)部碎片,這也是其優(yōu)勢所在,但其缺點(diǎn)很明顯就是利用率太低。
3實(shí)用的動態(tài)內(nèi)存分配
細(xì)心的讀者可能已經(jīng)發(fā)現(xiàn)上面的簡單動態(tài)內(nèi)存分配有一個缺點(diǎn),就是一個bit只能表示一個字節(jié),也就是說表示8個字節(jié)就需要一個字節(jié)的位圖,這種映射導(dǎo)致其內(nèi)存的
這對于很多情況是比較浪費(fèi)的。為了提高利用率,就必須將映射塊的粒度增大,也就是一個Bit的映射范圍對應(yīng)多個字節(jié)。
上圖給出了一個bit映射到64Byte,這樣:
雖然利用率變高了,但是其會產(chǎn)生內(nèi)部碎片,所謂內(nèi)部碎片就是在最小粒度內(nèi)無法使用的內(nèi)存空間,為何這個空間無法使用了,原因在于當(dāng)在申請內(nèi)存塊的時候,其內(nèi)存只能以64B對齊的,即使小于64B,也得按64B來看作,因?yàn)檫@個粒度已經(jīng)被bitmap標(biāo)記使用了,當(dāng)下次使用時,其無法被分配。
因此,可以看到,粒度越大,其可能產(chǎn)生的內(nèi)部內(nèi)存碎片越大,內(nèi)存利用率和碎片是需要權(quán)衡了,好的(算法)只能解決
溫馨提示
- 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. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 《GB-T 39700-2020硼泥處理處置方法》專題研究報告
- 《GBT 31430-2015 中國傳統(tǒng)色色名及色度特性》專題研究報告
- 《GB-T 24951-2010船舶和海上技術(shù) 船用雷達(dá)反射器》專題研究報告
- 2026年安陽職業(yè)技術(shù)學(xué)院單招職業(yè)傾向性考試題庫及答案詳解一套
- 清熱解毒用對它
- 災(zāi)后重建工程監(jiān)理協(xié)議
- 2025年CFA真題答案解析
- 2025年腸道傳染病知識培訓(xùn)試題及答案
- 2025年70歲考駕照三力測試題及答案
- 2025年治療精神障礙藥項目建議書
- 2025年居家養(yǎng)老助餐合同協(xié)議
- 石材行業(yè)合同范本
- 生產(chǎn)性采購管理制度(3篇)
- 2026年遠(yuǎn)程超聲診斷系統(tǒng)服務(wù)合同
- 中醫(yī)藥轉(zhuǎn)化研究中的專利布局策略
- COPD巨噬細(xì)胞精準(zhǔn)調(diào)控策略
- 網(wǎng)店代發(fā)合作合同范本
- 心源性休克的液體復(fù)蘇挑戰(zhàn)與個體化方案
- 九師聯(lián)盟2026屆高三上學(xué)期12月聯(lián)考英語(第4次質(zhì)量檢測)(含答案)
- 2025年醫(yī)院法律法規(guī)培訓(xùn)考核試題及答案
- (2025年)人民法院聘用書記員考試試題(含答案)
評論
0/150
提交評論