為什么需要虛擬內(nèi)存?虛擬內(nèi)存的概念與實(shí)現(xiàn)_第1頁
為什么需要虛擬內(nèi)存?虛擬內(nèi)存的概念與實(shí)現(xiàn)_第2頁
為什么需要虛擬內(nèi)存?虛擬內(nèi)存的概念與實(shí)現(xiàn)_第3頁
為什么需要虛擬內(nèi)存?虛擬內(nèi)存的概念與實(shí)現(xiàn)_第4頁
為什么需要虛擬內(nèi)存?虛擬內(nèi)存的概念與實(shí)現(xiàn)_第5頁
已閱讀5頁,還剩1頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

第第頁為什么需要虛擬內(nèi)存?虛擬內(nèi)存的概念與實(shí)現(xiàn)面試的時候經(jīng)常會被問到malloc的實(shí)現(xiàn)。從(操作系統(tǒng))層面來說,malloc確實(shí)是考察面試者對操作系統(tǒng)底層的存儲管理理解的一個很好的方式,涉及到虛擬內(nèi)存、分頁/分段等。下面逐個細(xì)說。

1.虛擬內(nèi)存

首先需要知道的是程序運(yùn)行起來的話需要被加載的物理內(nèi)存中,具體到計(jì)算機(jī)(硬件)就是內(nèi)存條。操作系統(tǒng)啟動的時候先把自己加載到物理內(nèi)存的固定位置(一般為底部),物理內(nèi)存的其他位置就用來運(yùn)行用戶程序。程序就是一堆指令,程序運(yùn)行可以簡單抽象為把指令加載到內(nèi)存中,然后(CPU)將指令從內(nèi)存載入執(zhí)行。

1.為什么需要虛擬內(nèi)存?

CPU對內(nèi)存的尋址最簡單的方式就是直接使用物理內(nèi)存地址,這種方式一般叫做物理尋址。早期的PC使用物理尋址,而且像(數(shù)字信號)(處理器)、(嵌入式)(微控制器)也使用物理尋址。物理尋址的好處是簡單,壞處也有很多,比如:

不安全:操作系統(tǒng)的地址直接暴露給用戶程序,用戶程序可以破壞操作系統(tǒng)。這種解決方案是采用特殊的硬件保護(hù)。

同時運(yùn)行多個程序比較困難:多個用戶程序如果都直接引用物理地址,很容易互相干擾。那么是不是可以通過不斷交換物理內(nèi)存和磁盤來保證物理內(nèi)存某一時間自由一個程序在運(yùn)行呢?當(dāng)時是可以的,但是這引入很多不必要和復(fù)雜的工作。

用戶程序大小受限:受制于物理內(nèi)存大小。我們現(xiàn)在的錯覺是應(yīng)用程序大小都小于物理內(nèi)存,這主要是因?yàn)楝F(xiàn)在PC的物理內(nèi)存都比較大。實(shí)際上只有1G物理內(nèi)存的PC是可以運(yùn)行2G的應(yīng)用程序的。

說明:

1、chunk指針指向chunk開始的地址;mem指針指向用戶內(nèi)存塊開始的地址。

2、p=0時,表示前一個chunk為空閑,prev_size才有效

3、p=1時,表示前一個chunk正在使用,prev_size無效p主要用于內(nèi)存塊的合并操作;ptmalloc分配的第一個塊總是將p設(shè)為1,以防止程序引用到不存在的區(qū)域

4、M=1為mmap映射區(qū)域分配;M=0為heap區(qū)域分配

5、A=0為主分配區(qū)分配;A=1為非主分配區(qū)分配。

空閑的chunk:

1.fastbins。

程序在運(yùn)行時會經(jīng)常需要申請和釋放一些較小的內(nèi)存空間。當(dāng)分配器合并了相鄰的幾個小的chunk之后,也許馬上就會有另一個小塊內(nèi)存的請求,這樣分配器又需要從大的空閑內(nèi)存中切分出一塊,這樣無疑是比較低效的,故而,malloc中在分配過程中引入了fastbins,

fastbins是bins的高速緩沖區(qū),大約有10個定長隊(duì)列。每個fastbin都記錄著一條freechunk的單鏈表(稱為binlist,采用單鏈表是出于fastbin中鏈表中部的chunk不會被摘除的特點(diǎn)),增刪chunk都發(fā)生在鏈表的前端。fastbins記錄著大小以8字節(jié)遞增的bin鏈表。

當(dāng)用戶釋放一塊不大于max_fast(默認(rèn)值64B)的chunk的時候,會默認(rèn)會被放到fastbins上。當(dāng)需要給用戶分配的chunk小于或等于max_fast時,malloc首先會到fastbins上尋找是否有合適的chunk,

除非特定情況,兩個毗連的空閑chunk并不會被合并成一個空閑chunk。不合并可能會導(dǎo)致碎片化問題,但是卻可以大大加速釋放的過程!

分配時,binlist中被檢索的第一個chunk將被摘除并返回給用戶。free掉的chunk將被添加在索引到的binlist的前端。

fastbin–>unsortedbin–>smallbin–>largebin–>topchunk–>擴(kuò)展堆

內(nèi)存回收流程

獲取分配區(qū)的鎖,保證線程安全。

如果free的是空指針,則返回,什么都不做。

判斷當(dāng)前chunk是否是mmap映射區(qū)域映射的內(nèi)存,如果是,則直接munmap()釋放這塊內(nèi)存。前面的已使用chunk的數(shù)據(jù)結(jié)構(gòu)中,我們可以看到有M來標(biāo)識是否是mmap映射的內(nèi)存。

判斷chunk是否與topchunk相鄰,如果相鄰,則直接和topchunk合并(和topchunk相鄰相當(dāng)于和分配區(qū)中的空閑內(nèi)存塊相鄰)。轉(zhuǎn)到步驟8

如果chunk的大小大于max_fast(64b),則放入unsortedbin,并且檢查是否有合并,有合并情況并且和topchunk相鄰,則轉(zhuǎn)到步驟8;沒有合并情況則free。

如果chunk的大小小于max_fast(64b),則直接放入fastbin,fastbin并沒有改變chunk的狀態(tài)。沒有合并情況,則free;有合并情況,轉(zhuǎn)到步驟7

在fastbin,如果當(dāng)前chunk的下一個chunk也是空閑的,則將這兩個chunk合并,放入unsortedbin上面。合并后的大小如果大于64B,會觸發(fā)進(jìn)行fastbins的合并操作,fastbins中的chunk將被遍歷,并與相鄰的空閑chunk進(jìn)行合并,合并后的chunk會被放到unsortedbin中,fastbin會變?yōu)榭?。合并后的chunk和topchunk相鄰,則會合并到topchunk中。轉(zhuǎn)到步驟8

判斷topchunk的大小是否大于mmap收縮閾值(默認(rèn)為128KB),如果是的話,對于主分配區(qū),則會試圖歸還topchunk中的一部分給操作系統(tǒng)。free結(jié)束。

使用注意事項(xiàng)

為了避免Glibc內(nèi)存暴增,需要注意:

1.后分配的內(nèi)存先釋放,因?yàn)閜tmalloc收縮內(nèi)存是從topchunk開始,如果與topchunk相鄰的chunk不能釋放,topchunk以下的chunk都無法釋放。

2.Ptmalloc不適合用于管理長生命周期的內(nèi)存,特別是持續(xù)不定期分配和釋放長生命周期的內(nèi)存,這將導(dǎo)致ptmalloc內(nèi)存暴增。

3.不要關(guān)閉ptmalloc的mmap分配閾值動態(tài)調(diào)整機(jī)制,因?yàn)檫@種機(jī)制保證了短生命周期的內(nèi)存分配盡量從ptmalloc緩存的內(nèi)存chunk中分配,更高效,浪費(fèi)更少的內(nèi)存。

4.多線程分階段執(zhí)行的程序不適合用ptmalloc,這種程序的內(nèi)存更適合用內(nèi)存池管理

5.盡量減少程序的線程數(shù)量和避免頻繁分配/釋放內(nèi)存。頻繁分配,會導(dǎo)致鎖的競爭,最終導(dǎo)致非主分配區(qū)增加,內(nèi)存碎片增高,并且性能降低。

6.防止內(nèi)存泄露,ptmalloc對內(nèi)存泄露是相當(dāng)敏感的,根據(jù)它的內(nèi)存收縮機(jī)制,如果與topchunk相鄰的那個chunk沒有回收,將導(dǎo)致topchunk一下很多的空閑內(nèi)存都無法返回給操作系統(tǒng)。

7.防止程序分配過多的內(nèi)存,或是由于glibc內(nèi)存暴增,導(dǎo)致

溫馨提示

  • 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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論