Linux系統(tǒng)是如何用虛擬內(nèi)存來欺騙應(yīng)用程序的?
- 一、讓有意義的事情變的有意思
- 二、物理內(nèi)存、虛擬內(nèi)存
- 三、Linux 中的換頁機(jī)制
一、讓有意義的事情變的有意思
昨天,看到下面這句話,送給您:讓有意思的事情變的有意義,讓有意義的事情變的有意思!不敢說這是一句人生哲學(xué),但是我們可以從這句話中找到我們做一件事情時(shí)的導(dǎo)向。
二、物理內(nèi)存、虛擬內(nèi)存
1. 從 x86 硬件角度看
在 x86 平臺(tái)上,主存儲(chǔ)器(也就是我們說說的內(nèi)存)負(fù)責(zé)存儲(chǔ)指令和數(shù)據(jù),它的作用僅次于 CPU。離開了內(nèi)存,性能再好的 CPU 也無法工作。就像人類的大腦一樣,如果沒有了記憶功能,再怎么聰明都無法施展。內(nèi)存被劃分為若干個(gè)存儲(chǔ)單元,從 0 開始編號(hào),一直到最大的那個(gè)存儲(chǔ)單元。CPU 通過地址總線來定位一個(gè)內(nèi)存的空間,通過數(shù)據(jù)總線從內(nèi)存中讀取數(shù)據(jù)、或者向內(nèi)存中寫入數(shù)據(jù)。我們都知道,同一個(gè) x86 平臺(tái)的硬件,既可以安裝 Windows 操作系統(tǒng),也可以安裝 Linux 操作系統(tǒng)。也就是說,在生產(chǎn)硬件的時(shí)候,它并不知道: 在自己的硬件之上,將會(huì)運(yùn)行什么樣的程序。也許會(huì)有高手直接寫一個(gè)牛逼的程序,直接來管理各種硬件資源、實(shí)現(xiàn)自己特定的功能呢?。?/p>不管如何,x86 平臺(tái)處理器架構(gòu)定義了自己的一套規(guī)則來訪問內(nèi)存。因此,從 x86 平臺(tái)硬件角度看,只有(物理)內(nèi)存這個(gè)東西,它壓根不知道什么是虛擬內(nèi)存。2. 從操作系統(tǒng)的角度看
操作系統(tǒng)最重要的功能就是:向應(yīng)用程序屏蔽了各種硬件資源,提供更加友好的接口,讓程序開發(fā)變得更容易。所以,操作系統(tǒng)會(huì)充分利用硬件的各種運(yùn)行機(jī)制,然后進(jìn)行抽象、包裝,面向應(yīng)用程序開發(fā)者提供一個(gè)穩(wěn)定的環(huán)境。那么對(duì)于內(nèi)存來說,操作系統(tǒng)向下對(duì)物理內(nèi)存進(jìn)行管理,向上對(duì)應(yīng)用程序提供虛擬內(nèi)存。3. 從應(yīng)用程序開發(fā)者的角度看
在很久以前,各種單片機(jī)、嵌入式 MCU 上,編寫應(yīng)用程序的時(shí)候,經(jīng)常會(huì)面對(duì)內(nèi)存很緊張的情況,這是就要很好的來優(yōu)化自己的程序,利用有限的硬件資源來實(shí)現(xiàn)一些功能。(突然想起多年之前的以為老工程師對(duì)我說,面對(duì)那么有限的一點(diǎn)資源,都會(huì)想哭!)隨著硬件的快速發(fā)展,這種硬件資源緊張的情況好像很少遇到了,給我們的感覺是:內(nèi)存我可以隨便用,想要多少就 malloc 多少。當(dāng)然了,操作系統(tǒng)會(huì)給出一些限制的,這只是操作系統(tǒng)層面的限制,因?yàn)樗凶约旱目剂恳蛩亍?/p>當(dāng)應(yīng)用程序提出申請(qǐng)一塊內(nèi)存空間時(shí),操作系統(tǒng)為了滿足應(yīng)用程序的需求,就會(huì)從虛擬內(nèi)存中“劃分”出一塊空間,然后把這個(gè)空間的開始地址返回給應(yīng)用程序。因此,從應(yīng)用程序開發(fā)的角度看,我們并不關(guān)心物理內(nèi)存、虛擬內(nèi)存。只要我 malloc 了,操作系統(tǒng)給我一個(gè)足夠的空間就行!至于這個(gè)空間是從哪里分配的,I don't care!也就是說,應(yīng)用程序是面向虛擬內(nèi)存編寫的,而不是面向物理內(nèi)存編寫的。當(dāng)然了,最終存儲(chǔ)數(shù)據(jù)的肯定是物理內(nèi)存,至于虛擬內(nèi)存如何與物理內(nèi)存建立對(duì)應(yīng)的映射關(guān)系,這就是由操作系統(tǒng)操心的事情了。每個(gè)應(yīng)用程序只能看到自己的虛擬內(nèi)存空間,這是一塊連續(xù)的空間,從而保證了不同應(yīng)用程序之間的隔離,達(dá)到安全目的。三、Linux 中的換頁機(jī)制
因此老板在對(duì)外宣傳的時(shí)候,就說:我的旅館很大,有 10000 個(gè)房間,歡迎前來入住!
- 旅行團(tuán)或顧客只能看到這個(gè)旅館的門頭和大廳,并不知道旅館里面的房間布局;
- 旅行團(tuán)并不會(huì)在同一時(shí)刻、扎堆的同時(shí)來住宿;
虛擬內(nèi)存?=?對(duì)外宣傳的 10000 個(gè)房間;?物理內(nèi)存 =?實(shí)際的 1000 個(gè)房間;??硬盤? ? ? ? =?只有床鋪的倉庫。?當(dāng)物理內(nèi)存不夠的時(shí)候,操作系統(tǒng)把一些物理內(nèi)存頁的內(nèi)存暫時(shí)存儲(chǔ)到空間更大、價(jià)格更便宜的硬盤上,然后就可以回收這些物理內(nèi)存繼續(xù)使用了。
讓知識(shí)流動(dòng)起來,越分享,越幸運(yùn)! ? ?
星標(biāo)公眾號(hào),能更快找到我!





