日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁(yè) > > 充電吧
[導(dǎo)讀]cc、gcc、g++、CC的區(qū)別概括gcc是C編譯器;g++是C++編譯器;linux下cc一般是一個(gè)符號(hào)連接,指向gcc;gcc和g++都是GUN(組織)的編譯器。而CC則一般是makefile里面

cc、gcc、g++、CC的區(qū)別概括

gcc是C編譯器;g++是C++編譯器;linux下cc一般是一個(gè)符號(hào)連接,指向gcc;gcc和g++都是GUN(組織)的編譯器。而CC則一般是makefile里面的一個(gè)名字,即宏定義,嘿,因?yàn)長(zhǎng)inux/Unix都是大小寫敏感的系統(tǒng),這點(diǎn)一定要注意。


cc是Unix系統(tǒng)的C Compiler,而gcc則是GNU Compiler Collection,GNU編譯器套裝。gcc原名為Gun C語(yǔ)言編譯器,因?yàn)樗局荒芴幚鞢語(yǔ)言,但gcc很快地?cái)U(kuò)展,包含很多編譯器(C、C++、Objective-C、Ada、Fortran、Java)。因此,它們是不一樣的,一個(gè)是古老的C編譯器,一個(gè)是GNU編譯器集合,gcc里面的C編譯器比cc強(qiáng)大多了,因此沒(méi)必要用cc。

下載不到cc的原因在于:cc來(lái)自于昂貴的Unix系統(tǒng),cc是商業(yè)軟件。

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

?

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

兩者都可以,但請(qǐng)注意:

(1)后綴為.c的,gcc把它當(dāng)作是C程序,而g++當(dāng)作是c++程序;后綴為.cpp的,兩者都會(huì)認(rèn)為是C++程序,注意,雖然C++是C的超集,但是兩者對(duì)語(yǔ)法的要求是有區(qū)別的。C++的語(yǔ)法規(guī)則更加嚴(yán)謹(jǐn)一些。

(2)編譯階段,g++會(huì)調(diào)用gcc,對(duì)于C++代碼,兩者是等價(jià)的,但是因?yàn)間cc命令不能自動(dòng)和C++程序使用的庫(kù)聯(lián)接,所以通常用g++來(lái)完成鏈接,為了統(tǒng)一起見(jiàn),干脆編譯/鏈接統(tǒng)統(tǒng)用g++了,這就給人一種錯(cuò)覺(jué),好像cpp程序只能用g++似的。

?

誤區(qū)二:gcc不會(huì)定義__cplusplus宏,而g++會(huì)

實(shí)際上,這個(gè)宏只是標(biāo)志著編譯器將會(huì)把代碼按C還是C++語(yǔ)法來(lái)解釋,如上所述,如果后綴為.c,并且采用gcc編譯器,則該宏就是未定義的,否則,就是已定義。

?

誤區(qū)三:編譯只能用gcc,鏈接只能用g++

嚴(yán)格來(lái)說(shuō),這句話不算錯(cuò)誤,但是它混淆了概念,應(yīng)該這樣說(shuō):編譯可以用gcc/g++,而鏈接可以用g++或者gcc -lstdc++。因?yàn)間cc命令不能自動(dòng)和C++程序使用的庫(kù)聯(lián)接,所以通常使用g++來(lái)完成聯(lián)接。但在編譯階段,g++會(huì)自動(dòng)調(diào)用gcc,二者等價(jià)。

?

C++的編譯器肯定可以編譯C的代碼,注意除了C++對(duì)C的語(yǔ)法擴(kuò)充之外,編譯和鏈接C和C++的標(biāo)準(zhǔn)庫(kù)通常也不一樣呢,用gcc而非g++也編譯了C++的程序就證明了這一點(diǎn)。

?

注:符號(hào)鏈接是一種特殊類型的文件,它的內(nèi)容只是一個(gè)字符串。它可能指向一個(gè)存在的文件也可能什么都不指向。當(dāng)您在命令行或程序里提到符號(hào)鏈接的時(shí)候,您實(shí)際上進(jìn)入了它指向的文件,前提是這個(gè)文件是存在的。

?

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

以?-g、-f、-m、-O、-W?或?--param?開頭的選項(xiàng)將由?gcc?自動(dòng)傳遞給其調(diào)用的
?不同子進(jìn)程。若要向這些進(jìn)程傳遞其他選項(xiàng),必須使用?-W?選項(xiàng)。



本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

如果你是在Linux下做開發(fā),你就必須知道Makefile是什么東西,如果不知道那就可以說(shuō)你不是一個(gè)合格的Linux開發(fā)工程師,因?yàn)镸akefile是必備的一項(xiàng)技能。那么,Makefile到底有什么作用呢?首先,gcc大...

關(guān)鍵字: Linux Makefile gcc

眾所周知,LLVM的Clang C / C ++編譯器比GCC提供更快的編譯速度。 但是,新版本的GCC中的編譯速度有所提高。

關(guān)鍵字: gcc Linux llvm

不同于家族式套娃,大眾CC誕生之初便憑借著無(wú)框車門、掀背尾門以及五門轎跑車的造型,被車迷譽(yù)為最美大眾。 日前,大官方發(fā)布了新款A(yù)rteon(國(guó)內(nèi)對(duì)應(yīng)一汽-大眾CC)的設(shè)計(jì)圖。新車作為中期改款車型,將提

關(guān)鍵字: cc 大眾

最近發(fā)布的 GCC 10 編譯器已對(duì) C++20 的主要功能協(xié)程(Co-Routines)進(jìn)行了初始支持,但是除非顯式地開啟該選項(xiàng),否則并不會(huì)啟用此功能。當(dāng) GCC 10 在 C++20 模式(std

關(guān)鍵字: gcc

對(duì)于c編譯器,大家應(yīng)早已熟悉。往期文章中,小編帶來(lái)諸多c編譯器相關(guān)文章,尤其是gcc c編譯器。本文中,小編將對(duì)gcc c編譯器如何編譯c程序予以介紹,并在文章的后半部分向大家講解如果選擇pic單片機(jī)的c編譯器。如果你對(duì)...

關(guān)鍵字: c編譯器 gcc pic 指數(shù)

c編譯器的重要性不言而喻,從往期c編譯器文章中,如c編譯器優(yōu)化、選定c編譯器等,想必大家對(duì)c編譯器均已有所了解。往期文章中,小編主要從宏觀方面為大家講解c編譯器,此外對(duì)于gcc c編譯器的講解也大多基于windows。本...

關(guān)鍵字: c編譯器 gcc Linux

c編譯器是編譯c程序的必備工具,缺少c編譯器情形下,c程序以及c++程序?qū)o(wú)法運(yùn)行。對(duì)于c編譯器,主要有3款。本文對(duì)于c編譯器的講解基于gcc c編譯器。此外,本文的gcc c編譯器為上篇文章的補(bǔ)充。如果你對(duì)本文內(nèi)容存在...

關(guān)鍵字: c編譯器 gcc ubuntu

c編譯器很多,每款c編譯器均有其特點(diǎn)。本文對(duì)于c編譯器的講解基于gcc c編譯器,針對(duì)gcc c編譯器,小編曾帶來(lái)諸多文章,但大多基于windows平臺(tái)。本文中,將基于ubuntu講解gcc c編譯器。此外,本文只為該教...

關(guān)鍵字: c編譯器 gcc ubuntu

對(duì)于c編譯器,大家并不陌生。小編前期同樣為c編譯器帶來(lái)了諸多好文,如果你對(duì)c編譯器感興趣,不妨在本網(wǎng)站內(nèi)進(jìn)行搜索哦。

關(guān)鍵字: c編譯器 gcc 靜態(tài)庫(kù)

自學(xué)c編譯器的朋友都知道。c編譯器作為常用軟件之一,并非具備無(wú)法逾越難度。對(duì)于c編譯器的學(xué)習(xí),往往需要具備一定耐心。本文對(duì)c編譯器的講解基于gcc c編譯器,同時(shí)本文承接“c編譯器so easy,gcc c編譯器生成、使...

關(guān)鍵字: c編譯器 gcc 靜態(tài)庫(kù)
關(guān)閉