虛擬記憶體和物理記憶體區別

2021-07-23 15:57:00 字數 1142 閱讀 6697

物理記憶體就是實際的記憶體,在cpu中指的是定址空間的大小,比如8086只有20根位址線,那麼它的定址空間就是1mb,我們就說8086能支援1mb的物理記憶體,及時我們安裝了128m的記憶體條在板子上,我們也只能說8086擁有1mb的物理記憶體空間。同理我們現在大部分使用的是32位的機子,32位的386以上cpu就可以支援最大4gb的物理記憶體空間了。

為什麼會有虛擬記憶體和物理記憶體區別呢?

因為物理記憶體的大小是有限的,虛擬記憶體是乙個程序需要的總共大小,大小有可能大於物理記憶體。正在執行的乙個程序,他所需的記憶體是有可能大於記憶體條容量之和的,比如你的記憶體條是256m,你的程式卻要建立乙個2g的資料區,那麼不是所有資料都能一起載入到記憶體(物理記憶體)中,勢必有一部分資料要放到其他介質中(比如硬碟),待程序需要訪問那部分資料時,在通過排程進入物理記憶體。所以,虛擬記憶體是程序執行時所有記憶體空間的總和,並且可能有一部分不在物理記憶體中,而物理記憶體就是我們平時所了解的記憶體條。

什麼是虛擬記憶體位址和物理記憶體位址呢?

假設你的計算機是32位,那麼它的位址匯流排是32位的,也就是它可以定址0~0xffffffff(4g)的位址空間,但如果你的計算機只有256m的物理記憶體0x~0x0fffffff(256m),同時你的程序產生了乙個不在這256m位址空間中的位址,那麼計算機該如何處理呢?回答這個問題前,先說明計算機的記憶體分頁機制。對虛擬記憶體位址空間(32位為4g)分頁產生頁(page),對物理記憶體位址空間(假設256m)分頁產生頁幀(page frame),這個頁和頁幀的大小是一樣大的,所以呢,在這裡,虛擬記憶體頁的個數勢必要大於物理記憶體頁幀的個數。在計算機上有乙個頁表(page table),就是對映虛擬記憶體頁到物理記憶體頁的,更確切的說是頁號到頁幀號的對映,而且是一對一的對映。但是問題來了,虛擬記憶體頁的個數 > 物理記憶體頁幀的個數,豈不是有些虛擬記憶體頁的位址永遠沒有對應的物理記憶體位址空間?不是的,作業系統是這樣處理的。作業系統有個頁面失效(page fault)功能。作業系統找到乙個最少使用的頁幀,讓他失效,並把它寫入磁碟,隨後把需要訪問的頁放到頁幀中,並修改頁表中的對映,這樣就保證所有的頁都有被排程的可能了。這就是處理虛擬記憶體位址到物理記憶體的步驟。

物理記憶體和虛擬記憶體

1.物理記憶體和虛擬記憶體 直接從物理記憶體讀取資料比從硬碟讀寫資料要快得多,因此,我們希望所有的資料的讀寫在記憶體中完成,但是記憶體是有限的,這樣就引出了物理記憶體與虛擬記憶體的概念。物理記憶體是系統硬體提供的記憶體大小,是真正的記憶體。虛擬記憶體是為了滿足物理記憶體不足而提出的策略,利用磁碟空間...

虛擬記憶體和物理記憶體

虛擬記憶體 物理記憶體 物理記憶體,在應用中,物理上,真實的插在板子上的記憶體是多大就是多大了。而在cpu中的概念,物理記憶體就是cpu的位址線可以直接進行定址的記憶體空間大小。比如8086只有20根位址線,那麼它的定址空間就是1mb,我們就說8086能支援1mb的物理記憶體,及時我們安裝了128m...

物理記憶體和虛擬記憶體

1 概念 物理記憶體 真實的硬體裝置 記憶體條 虛擬記憶體 利用磁碟空間虛擬出的一塊邏輯記憶體,用作虛擬記憶體的磁碟空間被稱為交換空間 swap space 為了滿足物理記憶體的不足而提出的策略 2.使用的順序 linux會在物理記憶體不足時,使用交換分割槽的虛擬記憶體。核心會將暫時不用的記憶體塊資...