C語言源代碼編譯全過程


示例代碼:

#include<stdio.h>
int main(){
    printf(“hello world\n”);
}

流程圖

C語言源代碼編譯過程圖

前提

       在計算中,任何的高級語言都不可以被計算機直接執行,都需要將高級語言轉化成爲計算機可以識別的計算機語言,所寫的代碼纔可以執行。從此我們可以看出,高級計算機語言,並不是直接爲計算機寫的,而是爲了程序員的方便。


       編譯共分爲四個階段:預處理階段、編譯階段、彙編階段、鏈接階段。

1、預處理階段:

       主要工作是將頭文件插入到所寫的代碼中,生成擴展名爲“.i”的文件替換原來的擴展名爲“.c”的文件,但是原來的文件仍然保留,只是執行過程中的實際文件發生了改變。(這裏所說的替換並不是指原來的文件被刪除)

2、彙編階段:

       插入彙編語言程序,將代碼翻譯成彙編語言。編譯器首先要檢查代碼的規範性、是否有語法錯誤等,以確定代碼的實際要做的工作,在檢查無誤後,編譯器把代碼翻譯成彙編語言,同時將擴展名爲“.i”的文件翻譯成擴展名爲“.s”的文件。

3、編譯階段:

將彙編語言翻譯成機器語言指令,並將指令打包封存成可重定位目標程序的格式,將擴展名爲“.s”的文件翻譯成擴展名爲“.o”的二進制文件。

4、鏈接階段:

       在示例代碼中,改代碼文件調用了標準庫中printf函數。而printf函數的實際存儲位置是一個單獨編譯的目標文件(編譯的結果也是擴展名爲“.o”的文件),所以此時主函數調用的時候,需要將該文件(即printf函數所在的編譯文件)與hello world文件整合到一起,此時鏈接器就可以大顯神通了,將兩個文件合併後生成一個可執行目標文件。


後續:

       將可執行目標文件加載到內存中,並運行,即可完成輸出的動作。

發佈了19 篇原創文章 · 獲贊 36 · 訪問量 17萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章