gcc 與 g++ 分別是 gnu 的 c & c++ 編譯器 gcc/g++ 在執行編譯工作的時候,總共需要4步:
1、預處理,生成 .i 的文件[預處理器cpp]
2、將預處理後的文件轉換成彙編語言, 生成文件 .s [編譯器egcs]
3、有彙編變爲目標代碼(機器代碼)生成 .o 的文件[彙編器as]
4、連接目標代碼, 生成可執行程序 [鏈接器ld]
可以使用的參數嗎有下面的這些:‘c’, ‘objective-c’, ‘c-header’, ‘c++’, ‘cpp-output’, ‘assembler’, 與 ‘assembler-with-cpp’。
-x none filename
關掉上一個選項,也就是讓gcc根據文件名後綴,自動識別文件類型 。
例子用法:
gcc -x c hello.pig -x none hello2.c
-c
只激活預處理,編譯,和彙編,也就是他只把程序做成obj文件
例子用法:
gcc -c hello.c
他將生成 .o 的 obj 文件
-S
只激活預處理和編譯,就是指把文件編譯成爲彙編代碼。
例子用法:
gcc -S hello.c
他將生成 .s 的彙編代碼,你可以用文本編輯器察看。
-E
只激活預處理,這個不生成文件, 你需要把它重定向到一個輸出文件裏面。
例子用法:
gcc -E hello.c > pianoapan.txt
gcc -E hello.c | more
慢慢看吧, 一個 hello word 也要與處理成800行的代碼。
-o
制定目標名稱, 默認的時候, gcc 編譯出來的文件是 a.out, 很難聽, 如果你和我有同感,改掉它, 哈哈。
例子用法:
gcc -o hello.exe hello.c (哦,windows用習慣了)
gcc -o hello.asm -S hello.c
-pipe
使用管道代替編譯中臨時文件, 在使用非 gnu 彙編工具的時候, 可能有些問題。
gcc -pipe -o hello.exe hello.c
-ansi
關閉 gnu c中與 ansi c 不兼容的特性, 激活 ansi c 的專有特性(包括禁止一些 asm inline typeof 關鍵字, 以及 UNIX,vax 等預處理宏)。
-fno-asm
此選項實現 ansi 選項的功能的一部分,它禁止將 asm, inline 和 typeof 用作關鍵字。
-fno-strict-prototype
只對 g++ 起作用, 使用這個選項, g++ 將對不帶參數的函數,都認爲是沒有顯式的對參數的個數和類型說明,而不是沒有參數。
而 gcc 無論是否使用這個參數, 都將對沒有帶參數的函數, 認爲城沒有顯式說明的類型。
-fthis-is-varialble
就是向傳統 c++ 看齊, 可以使用 this 當一般變量使用。
-fcond-mismatch
允許條件表達式的第二和第三參數類型不匹配, 表達式的值將爲 void 類型。
-funsigned-char 、-fno-signed-char、-fsigned-char 、-fno-unsigned-char
這四個參數是對 char 類型進行設置, 決定將 char 類型設置成 unsigned char(前兩個參數)或者 signed char(後兩個參數)。
-include file
包含某個代碼,簡單來說,就是便以某個文件,需要另一個文件的時候,就可以用它設定,功能就相當於在代碼中使用 #include。
例子用法:
gcc hello.c -include /root/pianopan.h
-imacros file
將 file 文件的宏, 擴展到 gcc/g++ 的輸入文件, 宏定義本身並不出現在輸入文件中。
-Dmacro
相當於 C 語言中的 #define macro
-Dmacro=defn
相當於 C 語言中的 #define macro=defn
-Umacro
相當於 C 語言中的 #undef macro
-undef
取消對任何非標準宏的定義
-Idir
在你是用 #include “file” 的時候, gcc/g++ 會先在當前目錄查找你所制定的頭文件, 如果沒有找到, 他回到默認的頭文件目錄找, 如果使用 -I 制定了目錄,他會先在你所制定的目錄查找, 然後再按常規的順序去找。
對於 #include, gcc/g++ 會到 -I 制定的目錄查找, 查找不到, 然後將到系統的默認的頭文件目錄查找 。
-I-
就是取消前一個參數的功能, 所以一般在 -Idir 之後使用。
-idirafter dir
在 -I 的目錄裏面查找失敗, 講到這個目錄裏面查找。
-iprefix prefix 、-iwithprefix dir
一般一起使用, 當 -I 的目錄查找失敗, 會到 prefix+dir 下查找
-nostdinc
使編譯器不再系統默認的頭文件目錄裏面找頭文件, 一般和 -I 聯合使用,明確限定頭文件的位置。
-nostdin C++
規定不在 g++ 指定的標準路經中搜索, 但仍在其他路徑中搜索, 此選項在創 libg++ 庫使用 。
-C
在預處理的時候, 不刪除註釋信息, 一般和-E使用, 有時候分析程序,用這個很方便的。
-M
生成文件關聯的信息。包含目標文件所依賴的所有源代碼你可以用 gcc -M hello.c 來測試一下,很簡單。
-MM
和上面的那個一樣,但是它將忽略由 #include 造成的依賴關係。
-MD
和-M相同,但是輸出將導入到.d的文件裏面
-MMD
和 -MM 相同,但是輸出將導入到 .d 的文件裏面。
-Wa,option
此選項傳遞 option 給彙編程序; 如果 option 中間有逗號, 就將 option 分成多個選項, 然 後傳遞給會彙編程序。
-Wl.option
此選項傳遞 option 給連接程序; 如果 option 中間有逗號, 就將 option 分成多個選項, 然 後傳遞給會連接程序。
-llibrary
制定編譯的時候使用的庫
例子用法
gcc -lcurses hello.c
使用 ncurses 庫編譯程序
-Ldir
制定編譯的時候,搜索庫的路徑。比如你自己的庫,可以用它制定目錄,不然編譯器將只在標準庫的目錄找。這個dir就是目錄的名稱。
-O0 、-O1 、-O2 、-O3
編譯器的優化選項的 4 個級別,-O0 表示沒有優化, -O1 爲默認值,-O3 優化級別最高。
-g
只是編譯器,在編譯的時候,產生調試信息。
-gstabs
此選項以 stabs 格式聲稱調試信息, 但是不包括 gdb 調試信息。
-gstabs+
此選項以 stabs 格式聲稱調試信息, 並且包含僅供 gdb 使用的額外調試信息。
-ggdb
此選項將儘可能的生成 gdb 的可以使用的調試信息。
-static
此選項將禁止使用動態庫,所以,編譯出來的東西,一般都很大,也不需要什麼動態連接庫,就可以運行。
-share
此選項將盡量使用動態庫,所以生成文件比較小,但是需要系統由動態庫。
-traditional
試圖讓編譯器支持傳統的C語言特性。
GCC 是 GNU 的 C 和 C++ 編譯器。實際上,GCC 能夠編譯三種語言:C、C++ 和 Object C(C 語言的一種面向對象擴展)。利用 gcc 命令可同時編譯並連接 C 和 C++ 源程序。
如果你有兩個或少數幾個 C 源文件,也可以方便地利用 GCC 編譯、連接並生成可執行文件。例如,假設你有兩個源文件 main.c 和 factorial.c 兩個源文件,現在要編 譯生成一個計算階乘的程序。
gcc 命令的常用選項
選項 解釋
-ansi 只支持 ANSI 標準的 C 語法。這一選項將禁止 GNU C 的某些特色, 例如 asm 或 typeof 關鍵詞。
-c 只編譯並生成目標文件。
-DMACRO 以字符串"1"定義 MACRO 宏。
-DMACRO=DEFN 以字符串"DEFN"定義 MACRO 宏。
-E 只運行 C 預編譯器。
-g 生成調試信息。GNU 調試器可利用該信息。
-IDIRECTORY 指定額外的頭文件搜索路徑DIRECTORY。
-LDIRECTORY 指定額外的函數庫搜索路徑DIRECTORY。
-lLIBRARY 連接時搜索指定的函數庫LIBRARY。
-m486 針對 486 進行代碼優化。
-o FILE 生成指定的輸出文件。用在生成可執行文件時。
-O0 不進行優化處理。
-O 或 -O1 優化生成代碼。
-O2 進一步優化。
-O3 比 -O2 更進一步優化,包括 inline 函數。
-shared 生成共享目標文件。通常用在建立共享庫時。
-static 禁止使用共享連接。
-UMACRO 取消對 MACRO 宏的定義。
-w 不生成任何警告信息。
-Wall 生成所有警告信息。