cc、gcc、g++、CC的區別概括


gcc是C編譯器;g++是C++編譯器;linux下cc一般是一個符號連接,指向gcc;gcc和g++都是GUN(組織)的編譯器。而CC則一般是makefile里面的一個名字,即宏定義,嘿,因為Linux/Unix都是大小寫敏感的系統,這點一定要注意。

cc是Unix系統的C Compiler,而gcc則是GNU Compiler Collection,GNU編譯器套裝。gcc原名為Gun C語言編譯器,因為它原本只能處理C語言,但gcc很快地擴展,包含很多編譯器(C、C++、Objective-C、Ada、Fortran、Java)。因此,它們是不一樣的,一個是古老的C編譯器,一個是GNU編譯器集合,gcc里面的C編譯器比cc強大多了,因此沒必要用cc。

下載不到cc的原因在於:cc來自於昂貴的Unix系統,cc是商業軟件。

Linux下的cc是gcc符號連接,可以通過$ls –l /usr/bin/cc來簡單察看,該變量是make程序的內建變量,默認指向gcc。cc符號鏈接和變量存在的意義在於源碼的移植性,可以方便的用gcc來編譯老的用cc編譯的Unix軟件,甚至連makefile都不用改在,而且也便於Linux程序在Unix下編譯。

 

誤區一:gcc只能編譯C代碼,g++只能編譯C++代碼。

兩者都可以,但請注意:

(1)后綴為.c的,gcc把它當作是C程序,而g++當作是c++程序;后綴為.cpp的,兩者都會認為是C++程序,注意,雖然C++是C的超集,但是兩者對語法的要求是有區別的。C++的語法規則更加嚴謹一些。

(2)編譯階段,g++會調用gcc,對於C++代碼,兩者是等價的,但是因為gcc命令不能自動和C++程序使用的庫聯接,所以通常用g++來完成鏈接,為了統一起見,干脆編譯/鏈接統統用g++了,這就給人一種錯覺,好像cpp程序只能用g++似的。

 

誤區二:gcc不會定義__cplusplus宏,而g++會

實際上,這個宏只是標志着編譯器將會把代碼按C還是C++語法來解釋,如上所述,如果后綴為.c,並且采用gcc編譯器,則該宏就是未定義的,否則,就是已定義。

 

誤區三:編譯只能用gcc,鏈接只能用g++

嚴格來說,這句話不算錯誤,但是它混淆了概念,應該這樣說:編譯可以用gcc/g++,而鏈接可以用g++或者gcc -lstdc++。因為gcc命令不能自動和C++程序使用的庫聯接,所以通常使用g++來完成聯接。但在編譯階段,g++會自動調用gcc,二者等價。

 

C++的編譯器肯定可以編譯C的代碼,注意除了C++對C的語法擴充之外,編譯和鏈接C和C++的標准庫通常也不一樣呢,用gcc而非g++也編譯了C++的程序就證明了這一點。

 

注:符號鏈接是一種特殊類型的文件,它的內容只是一個字符串。它可能指向一個存在的文件也可能什么都不指向。當您在命令行或程序里提到符號鏈接的時候,您實際上進入了它指向的文件,前提是這個文件是存在的。

 

用法:gcc [選項] 文件...
選項:
  -pass-exit-codes         在某一階段退出時返回最高的錯誤碼
  --help                   顯示此幫助說明
  --target-help            顯示目標機器特定的命令行選項
  (使用‘-v --help’顯示子進程的命令行參數)
  -dumpspecs               顯示所有內建 spec 字符串
  -dumpversion             顯示編譯器的版本號
  -dumpmachine             顯示編譯器的目標處理器
  -print-search-dirs       顯示編譯器的搜索路徑
  -print-libgcc-file-name  顯示編譯器伴隨庫的名稱
  -print-file-name=<庫>    顯示 <庫> 的完整路徑
  -print-prog-name=<程序>  顯示編譯器組件 <程序> 的完整路徑
  -print-multi-directory   顯示不同版本 libgcc 的根目錄
  -print-multi-lib         顯示命令行選項和多個版本庫搜索路徑間的映射
  -print-multi-os-directory 顯示操作系統庫的相對路徑
  -Wa,<選項>               將逗號分隔的 <選項> 傳遞給匯編器
  -Wp,<選項>               將逗號分隔的 <選項> 傳遞給預處理器
  -Wl,<選項>               將逗號分隔的 <選項> 傳遞給鏈接器
  -Xassembler <參數>       將 <參數> 傳遞給匯編器
  -Xpreprocessor <參數>    將 <參數> 傳遞給預處理器
  -Xlinker <參數>          將 <參數> 傳遞給鏈接器
  -combine                 將多個源文件一次性傳遞給匯編器
  -save-temps              不刪除中間文件
  -pipe                    使用管道代替臨時文件
  -time                    為每個子進程計時
  -specs=<文件>            用 <文件> 的內容覆蓋內建的 specs 文件
  -std=<標准>              指定輸入源文件遵循的標准
  --sysroot=<目錄>         將 <目錄> 作為頭文件和庫文件的根目錄
  -B <目錄>                將 <目錄> 添加到編譯器的搜索路徑中
  -b <機器>                為 gcc 指定目標機器(如果有安裝)
  -V <版本>                運行指定版本的 gcc(如果有安裝)
  -v                       顯示編譯器調用的程序
  -###                     與 -v 類似,但選項被引號括住,並且不執行命令
  -E                       僅作預處理,不進行編譯、匯編和鏈接
  -S                       編譯到匯編語言,不進行匯編和鏈接
  -c                       編譯、匯編到目標代碼,不進行鏈接
  -o <文件>                輸出到 <文件>
  -x <語言>                指定其后輸入文件的語言
                           允許的語言包括:c c++ assembler none
                           ‘none’意味着恢復默認行為,即根據文件的擴展名猜測
                           源文件的語言

以 -g、-f、-m、-O、-W 或 --param 開頭的選項將由 gcc 自動傳遞給其調用的
 不同子進程。若要向這些進程傳遞其他選項,必須使用 -W<字母> 選項。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM