示例代碼:
#include<stdio.h>
int main(){
printf(“hello world\n”);
}
流程圖:
前提:
在計算中,任何的高級語言都不可以被計算機直接執行,都需要將高級語言轉化成爲計算機可以識別的計算機語言,所寫的代碼纔可以執行。從此我們可以看出,高級計算機語言,並不是直接爲計算機寫的,而是爲了程序員的方便。
編譯共分爲四個階段:預處理階段、編譯階段、彙編階段、鏈接階段。
1、預處理階段:
主要工作是將頭文件插入到所寫的代碼中,生成擴展名爲“.i”的文件替換原來的擴展名爲“.c”的文件,但是原來的文件仍然保留,只是執行過程中的實際文件發生了改變。(這裏所說的替換並不是指原來的文件被刪除)
2、彙編階段:
插入彙編語言程序,將代碼翻譯成彙編語言。編譯器首先要檢查代碼的規範性、是否有語法錯誤等,以確定代碼的實際要做的工作,在檢查無誤後,編譯器把代碼翻譯成彙編語言,同時將擴展名爲“.i”的文件翻譯成擴展名爲“.s”的文件。
3、編譯階段:
將彙編語言翻譯成機器語言指令,並將指令打包封存成可重定位目標程序的格式,將擴展名爲“.s”的文件翻譯成擴展名爲“.o”的二進制文件。
4、鏈接階段:
在示例代碼中,改代碼文件調用了標準庫中printf函數。而printf函數的實際存儲位置是一個單獨編譯的目標文件(編譯的結果也是擴展名爲“.o”的文件),所以此時主函數調用的時候,需要將該文件(即printf函數所在的編譯文件)與hello world文件整合到一起,此時鏈接器就可以大顯神通了,將兩個文件合併後生成一個可執行目標文件。
後續:
將可執行目標文件加載到內存中,並運行,即可完成輸出的動作。