gcc/g++在執行編譯工作的時候,總共需要4步
1.預處理,生成.i的檔案[預處理器cpp]
2.將預處理後的檔案不轉換成組合語言,生成檔案.s[編譯器egcs]
3.有彙編變為目標**(機器**)生成.o的檔案[彙編器as]
4.連線目標**,生成可執行程式[鏈結器ld]
引數詳解
-c 只啟用預處理,編譯,和彙編,也就是他只把程式做成obj檔案
eg: gcc -c hello.c 生成.o的obj檔案
-o 制定目標名稱,預設的時候,gcc 編譯出來的檔案是a.out
eg:gcc -o hello.exe hello.c
gcc -o hello.asm -s hello.c
–d 允許從編譯程式命令列定義巨集符號
一共有兩種情況:一種是用-dmacro,相當於在程式中使用#define macro,另一種是用-dmacro=a,相當於程式中的#define macro a.
eg:如對下面這段**:
#ifdefine debug
printf("debug message/n");
#endif
編譯時可加上-ddebug引數,執行程式則列印出編譯資訊
-umacro 相當於c語言中的#undef macro
-undef 取消對任何非標準巨集的定義
-g指明編譯程式在編譯的輸出中應產生除錯資訊.這個除錯資訊使源**和變數名引用在除錯程式中或者當程式異常退出後在分析core檔案時可被使用.
-gstabs 此選項以stabs格式聲稱除錯資訊,但是不包括gdb除錯資訊.
-gstabs+ 此選項以stabs格式聲稱除錯資訊,並且包含僅供gdb使用的額外除錯資訊. -ggdb 此選項將盡可能的生成gdb的可以使用的除錯資訊.
-wall 以最高端別使用gnu編譯程式,專門用於顯示警告用!!
eg:gcc -wall hello.c
-i dir
在你是用#include"file"的時候,gcc/g++會先在當前目錄查詢你所制定的標頭檔案,如 果沒有找到,他回到預設的頭檔案目錄找,如果使用-i制定了目錄,他回先在你所制定的目錄查詢,然後再按常規的順序去找. 對於#include,gcc/g++會到-i制定的目錄查詢,查詢不到,然後將到系統的缺 省的頭檔案目錄查詢
eg:gcc -c -i/usr/local/include -i/opt/include hello.c 此時目錄搜尋會按給出的次序進行.
-i- 就是取消前乙個引數的功能,所以一般在-idir之後使用
-idirafter dir 在-i的目錄裡面查詢失敗,到這個目錄裡面查詢
-iprefix prefix -iwithprefix dir
一般一起使用,當-i的目錄查詢失敗,會到prefix+dir下查詢
-nostdinc
使編譯器不再系統預設的頭檔案目錄裡面找標頭檔案,一般和-i聯合使用,明確限定標頭檔案的位置
-nostdin c++
規定不在g++指定的標準路經中搜尋,但仍在其他路徑中搜尋,.此選項在創libg++庫使用
-s 只啟用預處理和編譯,就是指把檔案編譯成為彙編**。
eg:gcc -s hello.c 生成.s的彙編**,你可以用文字編輯器檢視
-e只啟用預處理,這個不生成檔案,你需要把它重定向到乙個輸出檔案裡面. 這個選項是相對標準的,它允許修改命令列以使編譯程式把預先處理的c檔案發到標準輸出,而不實際編譯**.在檢視c預處理偽指令和c巨集時,這是很有用的.可能的編譯輸出可重新定向到乙個檔案,然後用編輯程式來分析:
eg: gcc -c -e hello.c >cpp.out
此命令使include檔案和程式被預先處理並重定向到檔案cpp.out.以後可以用編輯程式或者分頁命令分析這個檔案,並確定最終的c語言**看起來如何.
gcc -e hello.c > pianoapan.txt
gcc -e hello.c | more 可以用來去掉檔案中的注釋
-pipe 使用管道代替編譯中臨時檔案,在使用非gnu彙編工具的時候,可能有些問題
eg:gcc -pipe -o hello.exe hello.c
-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分成多個選項,然 後傳遞給會連線程式.
-ldir指定連線庫的搜尋目錄,制定編譯的時候,搜尋庫的路徑。比如你自己的庫,可以用它制定目錄,不然編譯器將只在標準庫的目錄找。這個dir就是目錄的名稱。
-llibrary指定連線庫的名字
eg:gcc main.o -l/usr/lib -lqt -o hello
上面的命令把目標檔案main.o與庫qt相連線,連線時會到/usr/lib查詢這個庫檔案.也就是說-l與-l一般要成對出現.
-static
此選項將禁止使用動態庫,所以,編譯出來的東西,一般都很大,也不需要什麼 動態連線庫就可以執行.
-share 此選項將盡量使用動態庫,所以生成檔案比較小,但是需要系統由動態庫.
-traditional 試圖讓編譯器支援傳統的c語言特性
-ansi 關閉gnu c中與ansi c不相容的特性,啟用ansi c的專有特性(包括禁止一些
asm inl ine 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
eg: gcc hello.c -include /root/pianopan.h
-imacros file
將file檔案的巨集,擴充套件到gcc/g++的輸入檔案,巨集定義本身並不出現在輸入檔案中
-x language filename 設定檔案所使用的語言,使字尾名無效,對以後的多個有效.也就是根據約定c語言的後 綴名稱是.c的,而c++的字尾名是.c或者.cpp。這個引數對他後面的檔名都起作用,除非到了下乙個引數的使用。 可以使用的引數有下面的這些`c', `objective-c', `c-header', `c++', `cpp-output', `assembler', and `a ssembler-with-cpp'.
eg: gcc -x c hello.pig
-x none filename
關掉上乙個選項,也就是讓gcc根據檔名字尾,自動識別檔案型別
eg: gcc -x c hello.pig -x none hello2.c
gcc 編譯選項
gcc 編譯選項,自己翻譯的.gcc 編譯選項,自己翻譯的.o 設定輸出檔名 c 只編譯,不連線.e 只做預編譯.pipe 在多個編譯過程之間使用管道.version 顯示版本.static 靜態連線.ansi c 模式下支援所有 iso c90 標準的 c 程式,c 模式下去除對 gnu c 擴充...
gcc 編譯選項
wall 大部分警告 wextra 一些額外的警告 werror 當出現警告時轉為錯誤,停止編譯 wconversion 一些可能改變值的隱式轉換,給出警告。wno unused parameter 函式中出現未使用的引數,不給出警告。wold style cast c風格的轉換,給出警告 wove...
gcc 編譯選項
1.1 常規選項 1 沒有任何選項 gcc helloworld.c 結果會在與helloworld.c相同的目錄下產生乙個a.out的可執行檔案。2 o選項,指定輸出檔名 gcc o helloworld helloworld.c o意思是output即需要指定輸出的可執行檔案的名稱。這裡的名稱為...