在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

3天內不再提示

操作系統是如何啟動起來的?

Q4MP_gh_c472c21 ? 來源:碼農的荒島求生 ? 作者:碼農的荒島求生 ? 2022-04-18 14:55 ? 次閱讀

大家好,我是小風哥。

操作系統被稱為“第一個程序”,the first programme,原因很簡單,只有當操作系統啟動起來后才能運行我們編寫的程序,那么你有沒有想過這個問題:操作系統是怎樣啟動起來的呢?

實際上,這個過程就像發射火箭一樣有趣。看完這篇文章,你就明白啦~

5b497408-bed7-11ec-9e50-dac502259ad0.jpg

操作系統也是普通程序

首先我們必須意識到這樣兩點:

CPU執行的是機器指令,編譯器將程序翻譯后成了機器指令

操作系統本身也是一個程序,這個程序被編譯后也會生成一大堆機器指令

現在我們知道了,操作系統本身其實也是一大堆機器指令,既然是機器指令那么它必須得存放在什么地方。

存放在哪里呢?

想想我們編寫的程序,編譯后生成的是可執行文件,也就是說是以“文件”的形式存放的,并且存放在硬盤上,而操作系統也沒什么不同,編譯后生成的機器指令同樣是以文件的形式存放的,存放在哪里呢?可以存放在任何能存儲數據的介質,像CD、磁盤之類都可以。

5b523dd6-bed7-11ec-9e50-dac502259ad0.png

我們編寫的程序在啟動時被加載器——也就是loader,加載到內存,加載器也是一個程序,這是一個加載其它程序的程序;這么說可能有點拗口,但計算機系統中有大量類似的程序,編譯器是一個翻譯程序的程序、操作系統是一個運行其它程序的程序、鏈接器是一個鏈接程序的程序、解釋器是一個執行腳本程序的程序等等。

雞生蛋蛋生雞的問題

回到我們的主題,我們寫的代碼是loader加載到內存后運行的,那么操作系統這個程序是也同樣的道理,必須得有個什么東西也要把操作系統加載到內存中運行才可以,這個東西不叫loader,而是叫boot loader,其本身也是一個程序,它的任務就是加載一個更大的程序,就像這里的操作系統。

5b6a1474-bed7-11ec-9e50-dac502259ad0.png

此時這里會出現一個雞生蛋蛋生雞的,既然我們的程序是被加載器loader(操作系統的一部分)加載到內存中,而操作系統又是被boot loader這個加載程序加載到內存中的,那么又是什么加載器把boot loader這個加載程序加載到內存中呢?而又又是什么加載器把上一句中的什么加載器加載內存中呢?而又又又是什么。。?

5b7220e2-bed7-11ec-9e50-dac502259ad0.png

你會發現這個一個沒有出口的無窮遞歸啊有沒有,總得有個什么把前一個程序加載到內存,就好比今天的前一天是昨天、昨天的前一天是前天、前天的前一天是大前天,如果一直這樣思考下去那么時間到底在哪里開始的呢?時間到底有沒有開始(參考時間簡史或相對論)?

時間有沒有開始這個問題我不清楚,但操作系統啟動的這個問題我知道。

上述關于加載器以及加載加載器等問題全部指向了內存,讓我們好好想一想內存有什么特殊性?

內存斷電后是無法保存數據

程序員都知道內存只有在加電的情況下才可以保存數據(關于內存的實現原理你可以參考這篇《你管這破玩意叫CPU?》),那么很顯然,當斷電后內存中的內容就丟失了,那么又很顯然的,當你在按下計算機開關通電時,內存中的內容是未被初始化的,也就是說內存中的內容是無效的,此時的內存里還是一片荒蕪,這里沒有任何東西可供CPU來執行,這就好比大爆炸之前的宇宙。

5b7c661a-bed7-11ec-9e50-dac502259ad0.png

但我們的計算機總是能啟動起來,CPU必須得執行“一段什么程序”把第一個boot loader加載到內存中,由于此時內存中還什么都沒有,那么這段程序一定被保存在了其它地方。

保存在了哪里呢?

沒錯,這段程序就被保存在了BIOS的非易失性存儲ROM或者flash存儲中了,這里的代碼在即使斷電后也會保存下來,加電后CPU開始執行這里代碼,把boot loader加載到內存中,現在你應該明白第一個boot loader是怎樣被加載到內存的了吧。

5b8c0926-bed7-11ec-9e50-dac502259ad0.png

在早期的計算機上甚至專門有一個按鈕,讓用戶自己選擇該從哪里,比如打孔紙帶、打孔卡片或者硬盤,加載一個更復雜的程序來運行,操作面板上的旋鈕可以控制把這些程序加載到內存的什么位置上去:

火箭與操作系統啟動

然而現實情況比較復雜,我們剛才提到的boot loader這段小程序功能實在是太弱了,此時其能訪問的磁盤地址空間有限,不能把完整的內核全部加載到操作系統中,該怎么辦呢?

既然boot loader比較弱那么就換一個比較牛的loader程序來,就這樣出現了二階boot loader,second stage loader:

5b9c1f46-bed7-11ec-9e50-dac502259ad0.png

二階boot loader功能更為豐富,比如對硬件進行檢查、給用戶提供選項加載哪個操作系統等等,安裝多系統的同學應該知道,啟動時會給你一個選項到底是啟動windows還是linux,這就是二階boot loader的作用。

5bb25ac2-bed7-11ec-9e50-dac502259ad0.png

最終,操作系統被二階boot loader加載到內存中開始運行。

你會發現這個過程就和發射三級火箭一樣,最初一級火箭啟動,燃料用盡后二級火箭啟動,二級火箭完成使命后三級火箭啟動,最終把衛星送到太空,而計算機的啟動過程也類似。

最初是CPU運行BIOS中的一段代碼把一級boot loader加載到內存中運行,該程序又會把二級boot loader加載到內存運行,而二級boot loader又會把操作系統加載到內存中,此后控制權被轉移到操作系統,(所謂控制權是指CPU跳轉到操作系統的代碼),操作系統開始運行,經過一系列的初始化,比如硬件檢測、開啟必要的后臺進程等等,最終圖形界面或者命令行界面呈現出來。

接下來我們把這個過程細化一下。

更詳細的啟動過程

你在按下電源的瞬間相當于火箭點火,此時一級發動機開始工作。

加電CPU重置后開始在地址0xffff0處開始執行指令,這個地址其實是BIOS ROM的末尾處,該位置其實是一個跳轉指令,跳轉到ROM的一段啟動代碼上,該代碼會進行必要的自檢,Power-on self-test (POST),展示BIOS啟動界面等等,最重要的一步是找到啟動設備,所謂啟動設備就是指從哪里加載操作系統,比如CD-ROM、或者磁盤、甚至U盤等都可以作為啟動設備,早些年流行用U盤重新安裝系統,其實就是告訴BIOS的這段代碼從U盤中加載操作系統。

通常BIOS會把磁盤當做啟動設備(大部分情況下),此時BIOS中的這段代碼開始將磁盤的第0號塊加載到內存中,那么這第0號塊中有什么呢?沒錯,就是第一階段boot loader程序,這第0號塊也被稱之為Master Boot Record,MBR,肯定有不少同學聽說過。

5bce03da-bed7-11ec-9e50-dac502259ad0.png

到這里,火箭的一級發動機燃料用盡,二級發動機開始點火,BIOS中的這段代碼把控制權交給加載到內存boot loader,所謂控制權就是跳轉到boot loader程序,這樣CPU終于開始直接與內存交互了,CPU開始從內存中取出指令然后執行。

MBR中除了包含一段可執行代碼之外還有一個分區表,partition table,這個表的中的每一個條目本質上在說:“操作系統是否在我這個分區,我這個分區有多大”,CPU在執行MBR中的代碼時會去檢查操作系統存在哪個分區中,定位后開始從相應分區的起始位置讀取磁盤數據到內存中,這時的磁盤數據中保存的就是二階boot loader,second-stage boot loader,此時一階boot loader把控制權轉交給二階boot loader,火箭三級發動機開始工作。

2_boot loader的主要工作將操作系統加載到內存中,此后控制權轉交給操作系統,火箭的三級發動機完成使命,到這一時刻,操作系統開始接管計算機,操作系統經過一系列自身的初始化后創建出若干必要進程,至此計算機啟動完畢,衛星被成功送到了外太空中。

5bd8bcbc-bed7-11ec-9e50-dac502259ad0.png

然而限于篇幅這里依然沒有過多涉及細節,操作系統本身的初始化也是一個比較復雜的過程,感興趣的同學可以去翻閱相關操作系統的資料。

總結與腦洞

計算機的啟動是一個多階段的過程,當然在一些嵌入式設備等這個過程會簡化,但總體上也需要經過類似過程,只不過階段數會少一些。

回到最開始的那個問題,也就是時間有沒有開始,其實這個問題一些物理大牛已經回答過了,但我很想在這里開一個腦洞,當上帝在為自己創建的宇宙(計算機)加電的那一刻——也就是宇宙大爆炸時,時間開始了,時間這個概念是和宇宙(計算機)相伴相生的,如果沒有宇宙(計算機),時間這個概念其實是沒有意義的,就好比如果沒有計算機,加載這個概念其實是沒有意義的,你思考時間到底有沒有起點,這個問題就好比計算機中的程序在思考到底是誰把自己加載到內存的、又是誰把操作系統加載到內存中的等等。

好啦,腦洞就開到這里,現在你應該明白計算機啟動這個問題了吧~

END

審核編輯 :李倩

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

    關注

    68

    文章

    11045

    瀏覽量

    216099
  • 操作系統
    +關注

    關注

    37

    文章

    7101

    瀏覽量

    125017
  • 編譯器
    +關注

    關注

    1

    文章

    1657

    瀏覽量

    49916

原文標題:操作系統是如何啟動起來的?

文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦
    熱點推薦

    STM32H533的USB沒有啟動起來是怎么回事?

    有關USB配置,同樣的配置在STM32H503上就能正常運行,可以通過USB助手發現,在STM32H533就沒有任何反應,通過STM32CubeMX配置的模塊有USB、USBx、THREADx,通過測試發現程序能夠正常運行,就是USB沒有啟動起來,針對H533是需要特殊配置嗎?
    發表于 03-07 06:44

    deepin 23+樹莓派讓小車動起來

    deepin 23 +樹莓派還有啥新玩法? ? ? 前言 繼我們之前發布的樹莓派運行 deepin 23 系統教程后,此次我們將深入探索如何借助樹莓派實現與硬件的交互,進而精準控制小車的運行
    的頭像 發表于 02-12 09:12 ?669次閱讀
    deepin 23+樹莓派讓小車<b class='flag-5'>動起來</b>

    云天勵飛DeepEdge10芯片與國產鴻蒙操作系統完成適配

    日前,DeepEdge10芯片已完成國產鴻蒙操作系統的適配。目前已構建適配鴻蒙的芯片編譯平臺框架,完成圖形等子系統的適配。基于DeepEdge10的鴻蒙操作系統桌面環境已經可以成功啟動
    的頭像 發表于 01-24 10:14 ?981次閱讀

    國產銀河麒麟操作系統V10和星光麒麟V1.0操作系統如何選擇?

    國產銀河麒麟操作系統和星光麒麟操作系統都是由中國電子旗下科技企業麒麟軟件有限公司(簡稱“麒麟軟件”)開發的國產自主可控的操作系統。麒麟軟件介紹:麒麟軟件以安全可信操作系統技術為核心,面
    的頭像 發表于 01-24 09:14 ?1891次閱讀
    國產銀河麒麟<b class='flag-5'>操作系統</b>V10和星光麒麟V1.0<b class='flag-5'>操作系統</b>如何選擇?

    deepin操作系統介紹

    希望從自己的能力和對桌面操作系統的理解,能給 Linux 的用戶與開發者更多的選擇。我們也相信 deepin 能夠得到更多用戶的認可與喜愛,成為開源世界的最佳選擇。? 一、 deepin 操作系統 先說 Linux 操作系統,它
    的頭像 發表于 12-23 09:08 ?2097次閱讀
    deepin<b class='flag-5'>操作系統</b>介紹

    如何在windows上emulate不同操作系統

    一、虛擬化技術概述 虛擬化技術允許在單個物理機器上創建多個虛擬機,每個虛擬機都可以運行不同的操作系統。這使得我們可以在Windows系統上模擬其他操作系統,而無需購買額外的硬件。虛擬化技術的關鍵組件
    的頭像 發表于 12-05 15:50 ?742次閱讀

    linux是實時系統還是分時操作系統

    系統就難以滿足實時性需求,但是目前linux社區已經增加了較多版本的實時性補丁,給linux內核打上實時補丁后其實時性會得到大幅度提升,那么我們一起來看看兩者的區別。 如下分享一下:“linux是實時系統還是分時
    的頭像 發表于 11-11 11:43 ?1109次閱讀

    瑞薩和CJ125芯片使用SPI控制電壓?

    現在是mcu使用SPI和CJ125驅動起來了,但是怎么操作電壓電阻和電流呢
    發表于 10-29 11:23

    linux操作系統安裝步驟 linux操作系統的特點及組成

    Linux操作系統安裝步驟 Linux操作系統是一種開源的操作系統,它以其穩定性、安全性和靈活性而聞名。以下是安裝Linux操作系統的一般步驟,以Ubuntu為例: 1. 準備工作 在
    的頭像 發表于 10-21 11:24 ?1134次閱讀

    是否可以通過I2C在Android 8.1的嵌入式設備上將PCM1864EVM驅動起來

    16bit 4ch 3, 通過I2C在Android 8.1的嵌入式設備上將EVM驅動起來(是否提供linux or android開發包) BRs
    發表于 10-17 07:27

    嵌入式系統啟動流程

    嵌入式系統啟動流程是一個復雜但有序的過程,它涉及從系統上電到操作系統內核及應用程序啟動的多個階段。
    的頭像 發表于 10-05 17:44 ?833次閱讀

    e絡盟互動社區發起“動起來”設計大賽

    安富利旗下全球電子元器件產品與解決方案分銷商e絡盟發起了“Start a Movement動起來”設計挑戰賽,將選出 20 名工程師構建包含運動組件的自選項目。20名挑戰者將獲得由Analog
    的頭像 發表于 09-23 10:30 ?509次閱讀
    e絡盟互動社區發起“<b class='flag-5'>動起來</b>”設計大賽

    工控機支持什么操作系統

    工控機,全稱工業控制計算機(Industrial Personal Computer, IPC),支持多種操作系統以滿足不同行業和應用場景的需求。具體來說,工控機常見的操作系統包括:
    的頭像 發表于 09-11 09:24 ?962次閱讀

    簡單認識RTOS實時操作系統

    RTOS(Real Time Operating System,實時操作系統)是一種專門設計用于在嚴格時間限制內處理任務的操作系統。它以其高實時性、多任務處理能力和資源管理能力在工業自動化、醫療設備、航空航天、汽車電子等眾多領域得到廣泛應用。以下是對RTOS實時
    的頭像 發表于 08-20 11:20 ?4893次閱讀

    嵌入式實時操作系統:Intewell操作系統與VxWorks操作系統有啥區別

    Intewell操作系統和VxWorks操作系統都是工業領域常用的操作系統,它們各有特點和優勢。以下是它們之間的一些主要區別:
    的頭像 發表于 07-08 14:16 ?731次閱讀
    嵌入式實時<b class='flag-5'>操作系統</b>:Intewell<b class='flag-5'>操作系統</b>與VxWorks<b class='flag-5'>操作系統</b>有啥區別
    主站蜘蛛池模板: 日本5级床片全免费 | 中文字幕在线观看亚洲 | 日本三级精品 | 奇米视频7777 | 国产亚洲精品美女2020久久 | 中文字幕区 | 一级毛片无毒不卡直接观看 | 亚洲第一成年网 | 国产一二三区精品 | 最新黄色地址 | www在线观看 | 一区二区免费视频 | 亚洲三级色 | 欧美日韩一日韩一线不卡 | 很黄很污的视频网站 | 手机看片自拍自自拍日韩免费 | 亚洲日韩图片专区第1页 | 久久中文字幕一区二区 | 在线视频亚洲 | 一级做a爰片久久毛片图片 一级做a爰片久久毛片鸭王 | 五月婷婷丁香花 | 成年人看的黄色 | 久草在线免费资源站 | 国产91小视频在线观看 | 躁天天躁中文字幕在线 | 亚洲成综合人影院在院播放 | 久久精品影院永久网址 | 天天操电影 | 激情欧美一区二区三区中文字幕 | 亚洲欧美在线视频免费 | 丁香婷婷网 | 亚洲高清国产一线久久 | 速度与激情一 | 亚洲xxx视频| 日本黄段视频 | 香淫 | 免费一级欧美片在线观看 | 色天天综合色天天天天看大 | 曰韩毛片 | 性午夜影院 | 久草色香蕉 |