gcc 編譯過程及有關命令詳解

 用gcc編譯.c文件流程

1 預處理階段,輸入c的源文件,編譯器分析處理源代碼文件中的各類宏指令,如「#ifdef,#endif,#include」等,進行去註釋,頭文件展開,宏替換等操做 。用戶能夠用 -E 參數讓GCC在預處理結束後中止編譯過程(gcc -E [source file(.c)] -o [output file(.i)]。

2 編譯階段,從高級語言轉換爲彙編語言,GCC在預處理後要檢查代碼規範,是否有語法錯誤。無誤後翻譯爲彙編語言。 GCC 的 -S 選項讓GCC在進行完彙編以前中止,只進行編譯,不進行彙編。生成彙編代碼(gcc -F [source file(.i)] -o [output file(.s)]。

3 彙編階段。把編譯生成的「.s」文件生成目標二進制文件(.o文件)。(gcc -c [source file(.s)] -o [output file(.o)]。

4 連接階段。成功編譯後進入連接階段。該階段,編譯器把彙編生程的二進制代碼,程序中用到的庫文件連接起來,生成可執行文件。(gcc  [source file(.o)] -o [output file])。

總結:
1. gcc -E source_file.c
-E,只執行到預編譯。直接輸出預編譯結果。

2. gcc -S source_file.c
-S,只執行到源代碼到彙編代碼的轉換,輸出彙編代碼。

3. gcc -c source_file.c
-c,只執行到編譯,輸出目標文件。

4. gcc (-E/S/c/) source_file.c -o output_filename
-o, 指定輸出文件名,能夠配合以上三種標籤使用。
-o 參數能夠被省略。這種狀況下編譯器將使用如下默認名稱輸出:
-E:預編譯結果將被輸出到標準輸出端口(一般是顯示器)
-S:生成名爲source_file.s-c:生成名爲source_file.o的目標文件。
無標籤狀況:生成名爲a.out的可執行文件。

5. gcc -g source_file.c
-g,生成供調試用的可執行文件,能夠在gdb中運行。因爲文件中包含了調試信息所以運行效率很低,且文件也大很多。
這裏能夠用strip命令從新將文件中debug信息刪除。這是會發現生成的文件甚至比正常編譯的輸出更小了,這是由於strip把原先正常編譯中的一些額外信息(如函數名之類)也刪除了。用法爲 strip a.out

6. gcc -s source_file.c
-s, 直接生成與運用strip一樣效果的可執行文件(刪除了全部符號信息)。

7. gcc -O source_file.c
-O(大寫的字母O),編譯器對代碼進行自動優化編譯,輸出效率更高的可執行文件。
-O 後面還能夠跟上數字指定優化級別,如:
gcc -O2 source_file.c
數字越大,越加優化。可是一般狀況下,自動的東西都不是太聰明,太大的優化級別可能會使生成的文件產生一系列的bug。通常可選擇2;3會有必定風險。

8. gcc -Wall source_file.c
-W,在編譯中開啓一些額外的警告(warning)信息。-Wall,將全部的警告信息全開。

9. gcc source_file.c -L/path/to/lib -lxxx -I/path/to/include
-l, 指定所使用到的函數庫,本例中連接器會嘗試連接名爲libxxx.a的函數庫。
-L,指定函數庫所在的文件夾,本例中連接器會嘗試搜索/path/to/lib文件夾。
-I, 指定頭文件所在的文件夾,本例中預編譯器會嘗試搜索/path/to/include文件夾。函數

相關文章
相關標籤/搜索