国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

一個故事輕松看懂CPU內存管理技術

Linux愛好者 ? 來源:編程技術宇宙 ? 作者:編程技術宇宙 ? 2020-12-07 15:56 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

還記得我嗎,我是阿Q,CPU一號車間的那個阿Q。

今天忙里偷閑,來到廠里地址翻譯部門轉轉,負責這項工作的小黑正忙得滿頭大汗。

看到我的到來,小黑指著旁邊的座椅示意讓我坐下。

坐了好一會兒,小黑才從工位上忙完轉過身來,“實在不好意思阿Q,今天活太多,沒來得及招待你”

“剛忙什么呢,看你滿頭大汗的”,我問道。

“嗨,別提了,老是發現內存頁面錯誤,不停地要通知操作系統那邊去處理,真是懷念以前啊,沒有這么多破事兒要管”,小黑嘆了口氣。

我一聽來了興趣,“小黑你給我說說你們的工作唄,地址翻譯是怎么一回事兒,為什么懷念以前呢?”

小黑調整了下坐姿,咕嚕咕嚕喝了幾口水說道,“這話說來可就話長了”

接下來小黑開始給我講起了歷史故事······

8086

原來咱們的祖先叫8086,小黑還給我看了他的照片

那是一個純真質樸的年代,雖然工作性能不高,不過那個年代的程序都很簡單,我們的祖先一問世就成為了明星,稱得上那個時代的頂流了。

看到照片中的那些金屬針腳了嗎?那是我們CPU和外界打交道的觸角,每一根都有不同的作用。

通過這些觸角,CPU就可以跟內存打交道,獲取指令和數據,辛勤的干活啦。

那個年代,條件比較差,能湊合的就湊合,能共用的就共用。這不,你看祖先CPU的地址總線針腳和數據總線針腳就共用了。

祖先是一個16位的CPU,數據(Data)總線就有16位,一次性可以傳輸16個比特位。和地址(Address)總線湊合著一起共用,于是就取名AD0-AD15。

不過祖先的地址總線卻不止16個,還多出了A16-A19整整4個呢!這樣有20個地址線,可以尋址1MB的內存了!

但是祖先的寄存器都是16位的啊,只能存放16位的地址。不過他們很聰明,發明了一個叫分段式存儲管理的方法,把內存劃分為最大64KB的小塊,為什么是64KB呢,因為16位地址最多只能尋址這么大了。然后又加了幾個叫做段寄存器的東西,指向這些塊的開頭,這樣,通過段地址+段內偏移地址的方式,就能訪問更多的內存了。

32位時代

后來啊,祖先的那點計算能力越來越捉襟見肘,實在是跟不上時代了。家族中的年輕一代開始挑大梁,80286和80386CPU相繼問世,尤其是80386,成為了劃時代的存在。

到了80386時代,我們與外界通信的引腳就更多了,并且變成了32位的CPU,那個時候,生活條件就變好了,地址線和數據線再也不用共享引腳了。

后來,人類變得越來越貪心,想要一邊聽音樂,一邊還要上網,同時還要編輯文檔,這就同時需要運行多個程序。

這個時候,有人發現了商機,開發了一個叫操作系統的東西,原來那些程序不再直接和我們CPU打交道了,而是和操作系統打交道,操作系統再和我們打交道,中間商賺差價說的就是他們!

操作系統這玩意兒很聰明啊,通過時間片劃分讓我們CPU來輪流執行多個程序,一會兒讓我們執行音樂播放,一會兒讓我們執行瀏覽器程序,一會兒又讓我們執行文檔編輯程序。我們是無所謂啊,給什么代碼不是代碼啊,我們不挑,埋頭苦干就是了。人類的反應速度跟我們就差得遠了,他們還以為這些程序真的是同時執行的呢。

虛擬內存

不過隨之而來出現了一個大問題,這么多程序都要運行,大家擠在一個內存里,經常發生摩擦,沖突不斷。

先祖們為了此事殫精竭慮,終于想出了一個好辦法,一直沿用至今。

他們提出了一個虛擬地址的東西,所有程序使用的地址都是一個虛擬的地址,在真正和內存打交道的時候,咱們CPU內部工作人員再給翻譯成真實的內存地址,關于這事兒,內存那家伙一直被我們蒙在鼓里。

這樣一來,每個程序都可以用的是0x00000000到0xffffffff總共4GB這么大范圍的地址空間,當然不會真的給他們那么多空間,內存那家伙總共才4GB呢,而是要按需申請分配。分配的單元是按照頁來進行的,32位的CPU一個頁是4KB。這些分配管理的累活就讓操作系統來干了,中間商不能光拿好處不干正事,至于我們CPU,做好地址翻譯的工作就好了。

為此,在我們寄存器內部專門添置了一個新的寄存器CR3,用來指向一個地址翻譯查詢字典,字典劃分了兩級目錄。我們把一個32位的地址劃分了3部分,前面兩部分分別指向兩級目錄中的條目,用來定位這個地址在物理內存的哪個頁面,最后一部分就是指向物理內存頁面的偏移,這樣就完成了地址的翻譯工作。

每個進程有不同的地址空間,切換進程的時候,把CR3的內容換一下就使用新進程的翻譯字典,特別的方便。

我們把這種內存管理方式叫做分頁式內存管理。

真佩服先祖們的智慧,這樣巧妙的把各個程序隔離開來,后來我們把這種工作模式叫做保護模式,把之前那種直接使用真實內存地址的工作模式叫做實地址模式。

分頁交換

人類變得越來越貪婪,程序變得越來越多,對內存的需求也越來越大。隨著這些程序都不斷申請內存頁面,內存空間很快就要耗盡了。

我們看在眼里,急在心里,后來找操作系統協商,看看這問題該怎么辦。

操作系統那家伙也不賴,想出了一個好辦法。內存的大小有限,但是硬盤給力啊,硬盤空間大的多,去硬盤上劃一塊區域來,把內存里長時間沒有用到的頁面給換到這塊區域里去,然后做個標記。如果后面誰要訪問那個頁面,咱們CPU就檢查如果有這個標記,就發送一個頁錯誤的中斷信號告訴操作系統去把這個頁面換回來。

通過我們之間的配合,解決了內存緊張的危機。后來我們把這個技術叫做內存分頁交換。

現在

時間過得很快,到了我們這一輩,內存變得更大了,16GB都是小case,32GB也很常見。

除了內存,我們CPU本身也更先進了,別的不說,你光看看咱們現在的引腳數那比先祖們那幾輩就不可同日而語。

我們不僅從32位變成了64位,還從單核變成了多核,像我所在的CPU就有8個車間,8核并行執行,比起先祖那個年代簡直有云泥之別。

彩蛋

和小黑閑談間,我們車間的老K突然出現在了門口。
“阿Q原來你在這里,讓我好找,趕快回去吧,隔壁二號車間的虎子說我們改了他們的數據,上門來鬧事了······”

原文標題:一個故事看懂 CPU 內存管理技術

文章出處:【微信公眾號:Linux愛好者】歡迎添加關注!文章轉載請注明出處。

責任編輯:haq

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 寄存器
    +關注

    關注

    31

    文章

    5608

    瀏覽量

    130016
  • cpu
    cpu
    +關注

    關注

    68

    文章

    11281

    瀏覽量

    225095
  • 內存
    +關注

    關注

    9

    文章

    3211

    瀏覽量

    76383

原文標題:一個故事看懂 CPU 內存管理技術

文章出處:【微信號:LinuxHub,微信公眾號:Linux愛好者】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    探秘DS2731:緩存內存電池備份管理IC的卓越性能與應用

    探秘DS2731:緩存內存電池備份管理IC的卓越性能與應用 在電子設備的設計中,電源管理至關重要的環節,尤其是對于需要可靠備份電源的應
    的頭像 發表于 02-24 16:40 ?324次閱讀

    張圖看懂遠動通信裝置的工作流程

    ,就像場精準的“信息接力賽”。西格電力提供遠動通信裝置,咨詢服務:1.3.7-5.0.0.4-6.2.0.0,下面我們步步拆解,配合邏輯梳理,輕松看懂它的運作邏輯。
    的頭像 發表于 01-23 11:57 ?498次閱讀
    <b class='flag-5'>一</b>張圖<b class='flag-5'>看懂</b>遠動通信裝置的工作流程

    rk基于linux/android內存管理

    內存分布 ? U-Boot 由前級 Loader 加載到 CONFIG_SYS_TEXT_BASE 地址,初始化時會探明當前系統的總內存容 量, 32 位平臺上認為最大 4GB 可用(但是不影響
    的頭像 發表于 12-15 10:42 ?217次閱讀
    rk基于linux/android<b class='flag-5'>內存</b><b class='flag-5'>管理</b>

    不同位數的CPU的變量所占的內存

    )上述表格適用于KEIL C51 和 KEIL MDK兩版本中,不定適用于其它編輯器,具體內容,請查看KEIL軟件手冊。 2)CPU的位數不能決定int占幾個字節,int是
    發表于 12-09 07:30

    分享嵌入式開發學習路線

    如果你想要學習嵌入式開發,我建議按照這個學習路線準備: 1. 基礎鋪墊期(1-2月) 理解嵌入式系統的“硬件基礎”和“編程入門”,能看懂簡單電路,寫出基礎C語言代碼。這階段的學習對學歷沒有
    發表于 12-04 11:01

    WebGL/Canvas 內存泄露分析

    在構建高性能、長周期運行的 WebGL/Canvas 應用(如 3D 編輯器、數據可視化平臺)時,內存管理至關重要且極具挑戰性的課題。 開發者通常面臨的
    的頭像 發表于 10-21 11:40 ?418次閱讀
    WebGL/Canvas <b class='flag-5'>內存</b>泄露分析

    看懂晶豐明源BP2525x系列的區別

    看懂BP2525x之間的區別
    的頭像 發表于 09-13 15:22 ?2870次閱讀
    <b class='flag-5'>一</b>圖<b class='flag-5'>看懂</b>晶豐明源BP2525x系列的區別

    科普:什么AI 內存技術

    AI 內存種專為人工智能 (AI) 應用設計的新型內存技術。與傳統的通用內存(如 DDR5 或 LPDDR5)不同,AI
    的頭像 發表于 09-03 15:44 ?1405次閱讀

    連載|業余無線電史話():漫長的故事

    180米波段用莫爾斯電碼(CW)發射信號。資料來源:火花博物館。漫長的故事)如同任何科學故事
    的頭像 發表于 06-29 07:07 ?1147次閱讀
    連載|業余無線電史話(<b class='flag-5'>一</b>):<b class='flag-5'>一</b><b class='flag-5'>個</b>漫長的<b class='flag-5'>故事</b>

    黑芝麻智能芯多域零拷貝共享內存技術:破解車載大數據傳輸效能困局

    通過 零拷貝共享內存技術 ,黑芝麻智能解決車載多域間大數據傳輸的延遲與資源消耗問題。核心技術包括 全局內存管理單元 和 dmabuf機制優化
    發表于 06-23 17:53 ?1725次閱讀
    黑芝麻智能<b class='flag-5'>一</b>芯多域零拷貝共享<b class='flag-5'>內存</b><b class='flag-5'>技術</b>:破解車載大數據傳輸效能困局

    主板和CPU東西嗎?有什么區別?

    在數字化浪潮席卷的時代,電腦早已成為現代生活的核心樞紐。而在計算機硬件體系中,主板與CPU堪稱兩大支柱,共同構筑了整臺機器的運算中樞。雖然主板和CPU在功能定位上不同,但它們的協同運作,卻如同精密齒輪的咬合,直接決定了電腦性能的上限。
    的頭像 發表于 06-11 09:19 ?3303次閱讀

    博鼎彈簧發布數字目錄實現穩定高效且易于操作的技術數據管理

    CADENAS****技術顛覆產品數據提供方式:種全新的、行業領先的數字目錄 Mollificio Bordignon公司是家以生產各種高質量彈簧而聞名的公司,為了進步提高產品
    發表于 05-23 10:52

    HarmonyOS優化應用內存占用問題性能優化

    應用開發過程中注重內存管理,積極采取措施來減少內存占用,以優化應用程序的性能和用戶體驗。 HarmonyOS提供了內存
    發表于 05-21 11:27

    RISC-V五級流水線CPU設計

    本文實現的CPU五級流水線的精簡版CPU(也叫PCPU,即pipeline),包括IF(取指令)、ID(解碼)、EX(執行)、MEM(內存
    的頭像 發表于 04-15 09:46 ?1758次閱讀
    RISC-V五級流水線<b class='flag-5'>CPU</b>設計

    文詳解AXI DMA技術

    ,SG)功能還可以將數據移動任務從位于于處理器系統中的中央處理器(CPU)中卸載出來。可以通過AXI4-Lite從接口訪問初始化、狀態和管理寄存器。如圖4. 8展現了DMA IP的
    的頭像 發表于 04-03 09:32 ?2527次閱讀
    <b class='flag-5'>一</b>文詳解AXI DMA<b class='flag-5'>技術</b>