計算機(jī)系統(tǒng)漫游

#include <stdio.h>

int main(){

  printf("hello,world\n");
  return 0;
}
初見C程序我的表情是這樣的
那程序究竟是怎么執(zhí)行的?峭咒?
hello.c源碼ASCII碼表示

進(jìn)一步轉(zhuǎn)換成二進(jìn)制表示

00100011011010010110111001100011011011000111010101100100011001010010000000111100011100110111010001100100011010010110111100101110011010000011111000001010000010100110100101101110011101000010000001101101011000010110100101101110001010000010100101111011000010100000101000100000001000000111000001110010011010010110111001110100011001100010100000100010011010000110010101101100011011000110111100101100011101110110111101110010011011000110010001011100011011100010001000101001001110110000101000100000001000000111001001100101011101000111010101110010011011100010000000110000001110110000101001111101

源程序?qū)嶋H上就是一個由值0和1組成的位(bit)序列税弃。
8個位被組織成一組,稱為字節(jié)(Byte)

像上面這個程序只由ASCII字符構(gòu)成的文件稱為文本文件凑队,所有其他文件都稱為二進(jìn)制文件则果。

hello.c的表示方法說明了一個基本思想:系統(tǒng)中所有信息——包括磁盤文件、內(nèi)存中的程序漩氨、內(nèi)存中存放的用戶數(shù)據(jù)以及網(wǎng)絡(luò)上傳送的數(shù)據(jù)西壮,都是由一串比特表示的。區(qū)分不同數(shù)據(jù)對象的唯一方法就是我們讀到這些數(shù)據(jù)對象時的上下文叫惊。比如款青,在不同的上下文中,一個同樣的字節(jié)序列可能表示一個整數(shù)霍狰、浮點(diǎn)數(shù)抡草、字符串或者機(jī)器指令。

程序被其他程序翻譯成不同的格式

編譯系統(tǒng)

hello程序的生命周期是從一個高級C語言程序開始的蚓耽,因?yàn)檫@種形式能夠被人讀懂渠牲。然而為了在系統(tǒng)上執(zhí)行hello.c程序旋炒,每條C語句都必須被其他程序轉(zhuǎn)化為一系列的低級機(jī)器語言指令步悠。然后這些指令按照一種稱為可執(zhí)行目標(biāo)程序的格式打好包,并以二進(jìn)制磁盤文件的形式存放起來瘫镇。目標(biāo)程序也稱為可執(zhí)行目標(biāo)文件鼎兽。

  • 預(yù)處理階段:根據(jù)以字符#開頭的命令答姥,修改原始的C程序。
    比如hello.c的第一行#include <stdio.h>告訴預(yù)處理器讀取系統(tǒng)頭文件stdio.h的內(nèi)容谚咬,并把它直接插入程序文本中鹦付,結(jié)果就得到了另一個C程序,通常是以.i作為文件擴(kuò)展名择卦。

  • 編譯階段:編譯器將文本文件hello.i翻譯成文本文件hello.s敲长,它包含一個匯編語言程序。該程序包含函數(shù)main的定義秉继。

  • 匯編階段:匯編器將hello.s翻譯成機(jī)器語言指令祈噪,把這些指令打包成一種叫做可重定位目標(biāo)程序的格式,并將結(jié)果保存在文件hello.o中尚辑。hello.o文件是一個二進(jìn)制文件辑鲤。它包含的17個字節(jié)是函數(shù)main的指令編碼。

  • 鏈接階段:hello程序調(diào)用了printf函數(shù)杠茬,它是每個C編譯器都提供的標(biāo)準(zhǔn)C庫中的一個函數(shù)月褥。printf函數(shù)存在于一個名為printf.o的單獨(dú)的預(yù)編譯好了的目標(biāo)文件中,而這個文件必須以某種方式合并到hello.o程序中瓢喉。鏈接器負(fù)責(zé)處理這種合并宁赤,結(jié)果得到hello文件。它是一個可執(zhí)行目標(biāo)文件栓票,可以被加載到內(nèi)存中礁击,由系統(tǒng)執(zhí)行。

預(yù)處理 gcc –E hello.c –o hello.i
編譯 gcc –S hello.i –o hello.s
匯編 gcc –c hello.s –o hello.o
鏈接 gcc hello.o –o hello

處理器讀并解釋儲存在內(nèi)存中的指令:

此刻逗载,hello.c源程序已經(jīng)被編譯系統(tǒng)翻譯成了可執(zhí)行目標(biāo)文件hello哆窿,并被存放在磁盤上。為了理解運(yùn)行hello程序時到底發(fā)生了什么厉斟,我們需要了解一個典型系統(tǒng)的硬件組織挚躯。

一個典型系統(tǒng)的硬件組成
  • 總線:貫穿整個系統(tǒng)的是一組電子管道。它攜帶信息字節(jié)并負(fù)責(zé)在各個部件間傳遞擦秽。通陈肜螅總線被設(shè)計成傳送定長的字節(jié)塊,也就是字感挥。字中的字節(jié)數(shù)(即字長)是一個基本的系統(tǒng)參數(shù)缩搅,各個系統(tǒng)中都不盡相同。現(xiàn)在大多數(shù)機(jī)器字長要么是4個字節(jié)(32位)触幼,要么是8個字節(jié)(64位)硼瓣。

  • I/O設(shè)備:是系統(tǒng)與外部世界的聯(lián)系通道。

  • 主存:一個臨時存儲設(shè)備日麸,在處理器執(zhí)行程序時决采,用來存放程序和程序處理的數(shù)據(jù)碑诉。存儲器是一個線性的字節(jié)數(shù)組忍啸,每個字節(jié)多有唯一的地址察净,這些地址是從零開始的渊啰。一般來說胳蛮,組成程序的每條機(jī)器指令都由不同數(shù)量的字節(jié)構(gòu)成麸粮。C程序變量相對應(yīng)的數(shù)據(jù)項(xiàng)的大小是根據(jù)類型變化的半哟。比如酬滤,在運(yùn)行Linux的x86-64機(jī)器上,short類型數(shù)據(jù)需要2個字節(jié)寓涨,int和float類型需要4個字節(jié)敏晤,而long和double類型需要8個字節(jié)。

  • 處理器:解釋(或執(zhí)行)存儲在主存中指令的引擎缅茉。處理器的核心是一個大小為一個字的存儲設(shè)備(或寄存器)嘴脾,稱為程序計數(shù)器(PC),在任何時刻蔬墩,PC都指向主存中的某條機(jī)器語言指令(即含有該條指令的地址)译打。從系統(tǒng)通電開始,直到系統(tǒng)斷電拇颅,處理器一直不斷的執(zhí)行程序計數(shù)器指向的命令奏司,再更新程序計數(shù)器,使其指向下一條指令樟插。

運(yùn)行hello程序

從磁盤加載可執(zhí)行文件到主存
將輸出字符串從存儲器輸出到顯示器

操作系統(tǒng)管理硬件

hello程序運(yùn)行時沒有直接訪問鍵盤韵洋、顯示器、磁盤或者主存黄锤。取而代之的是搪缨,依靠操作系統(tǒng)提供的服務(wù)。所有應(yīng)用程序?qū)τ布牟僮鲊L試都必須通過操作系統(tǒng)鸵熟。
操作系統(tǒng)有兩個作用:

  1. 防止硬件被失控的應(yīng)用程序?yàn)E用副编;
  2. 向應(yīng)用程序提供簡單一致的機(jī)制來控制復(fù)雜而又通常大不相同的低級硬件設(shè)備。操作系統(tǒng)通過幾個基本的抽象概念(進(jìn)程流强、虛擬內(nèi)存和文件)來實(shí)現(xiàn)這兩個功能痹届。
屏幕快照 2018-05-18 11.47.16.png
  • 進(jìn)程:是操作系統(tǒng)對一個正在運(yùn)行的程序的一種抽象。

  • 虛擬內(nèi)存:它為每個進(jìn)程提供一個假象打月,即每個進(jìn)程都在獨(dú)占的使用主存队腐。每個進(jìn)程看到的內(nèi)存都是一致的,稱為虛擬地址空間奏篙。

進(jìn)程的虛擬地址空間

上圖所示是Linux進(jìn)程的虛擬地址空間柴淘。在Linux中,地址空間最上面的區(qū)域是保留給操作系統(tǒng)中的代碼和數(shù)據(jù)的,這對所有進(jìn)程來說都是一樣的悠就。地址空間的底部區(qū)域存放用戶進(jìn)程定義的代碼和數(shù)據(jù)千绪。圖中地址是從下往上增大的充易。

每個進(jìn)程看到的虛擬地址空間由大量準(zhǔn)確定義的區(qū)構(gòu)成梗脾,每個區(qū)都有專門的功能。

  • 程序代碼和數(shù)據(jù):對所有的進(jìn)程來說盹靴,代碼是從一固定地址開始炸茧,緊接著是和C全局變量相對應(yīng)的數(shù)據(jù)位置。代碼和數(shù)據(jù)區(qū)是直接按照可執(zhí)行目標(biāo)文件的內(nèi)容初始化的稿静,此處就是可執(zhí)行目標(biāo)文件hello梭冠。
  • 堆:代碼和數(shù)據(jù)區(qū)后緊跟著的是運(yùn)行時堆。代碼和數(shù)據(jù)區(qū)在進(jìn)程一開始時就被指定來大小改备。與此不同控漠,當(dāng)調(diào)用像malloc和free這樣的C標(biāo)準(zhǔn)庫函數(shù)時,堆可以在運(yùn)行時動態(tài)的擴(kuò)展和收縮悬钳。
  • 共享庫:大約在地址空間的中間部分是一塊用來存放像C標(biāo)準(zhǔn)庫和數(shù)學(xué)庫這樣的共享庫的代碼和數(shù)據(jù)的區(qū)域盐捷。
  • 棧:位于用戶虛擬地址空間頂部的是用戶棧,編譯器用它來實(shí)現(xiàn)函數(shù)調(diào)用默勾。和堆一樣碉渡,用戶棧在程序執(zhí)行期間可以動態(tài)的擴(kuò)展和收縮。特別的母剥,我們每次調(diào)用一個函數(shù)滞诺,棧就會增長;從函數(shù)返回時环疼,棧就會收縮习霹。
  • 內(nèi)核虛擬地址。地址空間頂部的區(qū)域是為內(nèi)核保留的炫隶。不允許應(yīng)用程序讀寫這個區(qū)域的內(nèi)容或直接調(diào)用內(nèi)核代碼定義的函數(shù)序愚。相反,它們必須調(diào)用內(nèi)核來執(zhí)行這些操作等限。

文件:文件就是字節(jié)序列爸吮,僅此而已。每個I/O設(shè)備望门,包括磁盤形娇、鍵盤、顯示器筹误,甚至包括網(wǎng)絡(luò)桐早,都可以看成是文件。文件這個簡單而精致的概念是非常強(qiáng)大的,因?yàn)樗驊?yīng)用程序提供了一個統(tǒng)一的視圖哄酝,來看待系統(tǒng)中可能含有的所有各式各樣的I/O設(shè)備友存。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市陶衅,隨后出現(xiàn)的幾起案子屡立,更是在濱河造成了極大的恐慌,老刑警劉巖搀军,帶你破解...
    沈念sama閱讀 219,366評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件膨俐,死亡現(xiàn)場離奇詭異,居然都是意外死亡罩句,警方通過查閱死者的電腦和手機(jī)焚刺,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來门烂,“玉大人乳愉,你說我怎么就攤上這事⊥驮叮” “怎么了蔓姚?”我有些...
    開封第一講書人閱讀 165,689評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長氓润。 經(jīng)常有香客問我赂乐,道長,這世上最難降的妖魔是什么咖气? 我笑而不...
    開封第一講書人閱讀 58,925評論 1 295
  • 正文 為了忘掉前任挨措,我火速辦了婚禮,結(jié)果婚禮上崩溪,老公的妹妹穿的比我還像新娘浅役。我一直安慰自己,他們只是感情好伶唯,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,942評論 6 392
  • 文/花漫 我一把揭開白布觉既。 她就那樣靜靜地躺著,像睡著了一般乳幸。 火紅的嫁衣襯著肌膚如雪瞪讼。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,727評論 1 305
  • 那天粹断,我揣著相機(jī)與錄音符欠,去河邊找鬼。 笑死瓶埋,一個胖子當(dāng)著我的面吹牛希柿,可吹牛的內(nèi)容都是我干的诊沪。 我是一名探鬼主播,決...
    沈念sama閱讀 40,447評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼曾撤,長吁一口氣:“原來是場噩夢啊……” “哼端姚!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起挤悉,我...
    開封第一講書人閱讀 39,349評論 0 276
  • 序言:老撾萬榮一對情侶失蹤渐裸,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后尖啡,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體橄仆,經(jīng)...
    沈念sama閱讀 45,820評論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡剩膘,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,990評論 3 337
  • 正文 我和宋清朗相戀三年衅斩,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片怠褐。...
    茶點(diǎn)故事閱讀 40,127評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡畏梆,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出奈懒,到底是詐尸還是另有隱情奠涌,我是刑警寧澤,帶...
    沈念sama閱讀 35,812評論 5 346
  • 正文 年R本政府宣布磷杏,位于F島的核電站溜畅,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏极祸。R本人自食惡果不足惜慈格,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,471評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望遥金。 院中可真熱鬧浴捆,春花似錦、人聲如沸稿械。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,017評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽美莫。三九已至页眯,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間厢呵,已是汗流浹背窝撵。 一陣腳步聲響...
    開封第一講書人閱讀 33,142評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留述吸,地道東北人忿族。 一個月前我還...
    沈念sama閱讀 48,388評論 3 373
  • 正文 我出身青樓锣笨,卻偏偏與公主長得像,于是被迫代替她去往敵國和親道批。 傳聞我的和親對象是個殘疾皇子错英,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,066評論 2 355

推薦閱讀更多精彩內(nèi)容