linux內(nèi)存虛擬地址映射物理地址
Linux 內(nèi)核給每個(gè)進(jìn)程都提供了一個(gè)獨(dú)立的虛擬地址空間,并且這個(gè)地址空間是連續(xù)的。虛擬地址空間的內(nèi)部又被分為內(nèi)核空間和用戶空間兩部分。不同字長(也就是單個(gè) CPU 指令可以處理數(shù)據(jù)的最大長度)的處理器,地址空間的范圍也不同。
其中,所有進(jìn)程的內(nèi)核空間,關(guān)聯(lián)的都是相同的物理內(nèi)存。進(jìn)程切換到內(nèi)核態(tài)后,才可以訪問內(nèi)核空間內(nèi)存。我們下面說到的分段只針對用戶空間。
有兩種方式管理虛擬地址與物理地址之間的關(guān)系。
1、段式管理(Segment):由段選擇子和段內(nèi)偏移量找到物理地址。
用戶空間從低地址到高地址分別是五種不同的內(nèi)存段。
代碼段(只讀段),包括代碼和常量等。
數(shù)據(jù)段,包括全局變量等。
堆,包括動態(tài)分配的內(nèi)存,從低地址開始向上增長。
文件映射段,包括動態(tài)庫、共享內(nèi)存等,從高地址開始向下增長。(本圖沒有畫出)
棧,包括局部變量和函數(shù)調(diào)用的上下文等。棧的大小是固定的,一般是 8 MB。
分段容易出現(xiàn)碎片,內(nèi)存交換效率低(不容易換出到磁盤)的問題。為了解決這兩個(gè)問題,就出現(xiàn)了內(nèi)存分頁。
2、頁式管理(Paging):虛擬地址分為兩部分,頁號和頁內(nèi)偏移。
MMU 規(guī)定了一個(gè)內(nèi)存映射的最小單位,也就是頁,通常是 4 KB 大小。為了解決頁表項(xiàng)過多的問題,有多級頁表和大頁兩種方式。
并不是給進(jìn)程的所有的虛擬內(nèi)存都會分配物理內(nèi)存,只有那些實(shí)際使用的虛擬內(nèi)存才分配物理內(nèi)存。這叫程序的局部性原理。根據(jù)此原理,為了提高訪問速度,MMU(Memory Manage Unit)里配有一個(gè)硬件:TLB(Translation Lookaside Buffer)。用于緩存進(jìn)程常用頁表。
內(nèi)存分段和內(nèi)存分頁并不是對立的,他們組合起來使用,通常稱為段頁式內(nèi)存管理。
程序所使用的地址,稱為邏輯地址;
通過段式內(nèi)存管理映射的地址,稱為虛擬地址(線性地址);
通過頁式內(nèi)存管理將線性地址映射成物理地址。

最新活動更多
-
10月23日火熱報(bào)名中>> 2025是德科技創(chuàng)新技術(shù)峰會
-
10月23日立即報(bào)名>> Works With 開發(fā)者大會深圳站
-
10月24日立即參評>> 【評選】維科杯·OFweek 2025(第十屆)物聯(lián)網(wǎng)行業(yè)年度評選
-
11月27日立即報(bào)名>> 【工程師系列】汽車電子技術(shù)在線大會
-
12月18日立即報(bào)名>> 【線下會議】OFweek 2025(第十屆)物聯(lián)網(wǎng)產(chǎn)業(yè)大會
-
精彩回顧立即查看>> 【限時(shí)福利】TE 2025國際物聯(lián)網(wǎng)展·深圳站
推薦專題
- 1 先進(jìn)算力新選擇 | 2025華為算力場景發(fā)布會暨北京xPN伙伴大會成功舉辦
- 2 人形機(jī)器人,正狂奔在批量交付的曠野
- 3 宇樹機(jī)器人撞人事件的深度剖析:六維力傳感器如何成為人機(jī)安全的關(guān)鍵屏障
- 4 解碼特斯拉新AI芯片戰(zhàn)略 :從Dojo到AI5和AI6推理引擎
- 5 AI版“四萬億刺激”計(jì)劃來了
- 6 2025年8月人工智能投融資觀察
- 7 8 a16z最新AI百強(qiáng)榜:硅谷頂級VC帶你讀懂全球生成式AI賽道最新趨勢
- 9 Manus跑路,大廠掉線,只能靠DeepSeek了
- 10 地平線的野心:1000萬套HSD上車