gcc和g 的區別

2021-07-07 04:32:46 字數 4772 閱讀 2052

gcc和g++的區別

我們在編譯c/c++**的時候,有人用gcc,有人用g++,於是各種說法都來了,譬如c**用gcc,而c++**用g++,或者說編譯用gcc,鏈結用g++,一時也不知哪個說法正確,如果再遇上個extern "c",分歧就更多了,這裡我想作個了結,畢竟知識的目的是令人更清醒,而不是更糊塗。

誤區一:gcc只能編譯c**,g++只能編譯c++**

兩者都可以,但是請注意:

1.字尾為.c的,gcc把它當作是c程式,而g++當作是c++程式;字尾為.cpp的,兩者都會認為是c++程式,注意,雖然c++是c的超集,但是兩者對語法的要求是有區別的,例如:

#include

int main(int argc, char* argv)

int printstring(char* string)

如果按照c的語法規則,ok,沒問題,但是,一旦把字尾改為cpp,立刻報三個錯:「printstring未定義」;

「cannot convert `char**' to `char*」;

」return-statement with no value「;

分別對應前面紅色標註的部分。可見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,二者等價。

誤區四:extern "c"與gcc/g++有關係

實際上並無關係,無論是gcc還是g++,用extern "c"時,都是以c的命名方式來為symbol命名,否則,都以c++方式命名。試驗如下:

me.h:

extern "c" void cppprintf(void);

me.cpp:

#include

#include "me.h"

using namespace std;

void cppprintf(void)

test.cpp:

#include

#include

#include "me.h"       

int main(void)

1. 先給me.h加上extern "c",看用gcc和g++命名有什麼不同

[root@root g++]# g++ -s me.cpp

[root@root g++]# less me.s

.globl _z9cppprintfv        //注意此函式的命名

.type   cppprintf, @function

[root@root gcc]# gcc -s me.cpp

[root@root gcc]# less me.s

.globl _z9cppprintfv        //注意此函式的命名

.type   cppprintf, @function

完全相同!

2. 去掉me.h中extern "c",看用gcc和g++命名有什麼不同

[root@root gcc]# gcc -s me.cpp

[root@root gcc]# less me.s

.globl _z9cppprintfv        //注意此函式的命名

.type   _z9cppprintfv, @function

[root@root g++]# g++ -s me.cpp

[root@root g++]# less me.s

.globl _z9cppprintfv        //注意此函式的命名

.type   _z9cppprintfv, @function

完全相同!

【結論】完全相同,可見extern "c"與採用gcc/g++並無關係,以上的試驗還間接的印證了前面的說法:在編譯階段,g++是呼叫gcc的。

**********==例子

gcc和g++到底有什麼區別?2007-11-12 09:33今天編譯乙個很普通的c++程式,如下:

1 #include 《iostream》

23 void function1()

67 void function2()

1112 void function3()

1819 int main()

33 }

編譯命令列: gcc -pg -o sample3 sample3.cpp

結果是:

/tmp/cck9wdpz.o: in function `__static_initialization_and_destruction_0(int, int)':

sample3.cpp:(.text+0x12c): undefined reference to `std::ios_base::init::init()'

/tmp/cck9wdpz.o: in function `__tcf_0':

sample3.cpp:(.text+0x183): undefined reference to `std::ios_base::init::~init()'

/tmp/cck9wdpz.o:(.eh_frame+0x11): undefined reference to `__gxx_personality_v0'

collect2: ld returned 1 exit status以前因為工作內容的關係,沒用gcc編譯過c++的**。或者是其他同事已經寫好了makefile,沒怎麼關心過這個問題。不過以前和乙個同事爭論過,他說c++的**必須要用g++編譯,否則編譯不過去,因為gcc是編譯c code的,而g++才是編譯c++的。我當時就知道肯定不對,因為gcc是gnu compiler collection的縮寫,而不是gnu c compiler。理論上所有的gcc支援的不同語言的**都可以用gcc編譯(如果我錯了請糾正我)。當時沒空爭論這個問題,結果今天自己碰上了。google了一下,又試了試,確實用g++可以編譯過去

g++ -pg -o sample3 sample3.cpp 不服不服,繼續嘗試發現用gcc也可以,不過要加上指定的標準c++庫 如下:

gcc -pg -o sample3 sample3.cpp -lstdc++

所以,gcc是可以編譯c++ **的,g++不過是隱含鏈結某些庫

本人親身體會:檔案字尾名真的很重要!

我的乙個c++程式命名為:mgqw.c 用g++ mgqw.c -o mgqw編譯沒有問題,

而如果使用:gcc mgqw.c -o mgqw -lstdc++的話則會報類似下面的錯誤:

mgqw.c:68: 錯誤:expected 『=』, 『,』, 『;』, 『asm』 or 『__attribute__』 before 『*』 token

mgqw.c: 在函式 『main』 中:

mgqw.c:909: 錯誤:expected 『=』, 『,』, 『;』, 『asm』 or 『__attribute__』 before 『*』 token

mgqw.c: 在函式 『switchgame』 中:

mgqw.c:1351: 錯誤:expected expression before 『static』

mgqw.c:1352: 錯誤:『cjpsw』 未宣告 (在此函式內第一次使用)

mgqw.c:1352: 錯誤:(即使在乙個函式內多次出現,每個未宣告的識別符號在其

mgqw.c:1352: 錯誤:所在的函式內只報告一次。)

mgqw.c:1358: 錯誤:expected expression before 『static』

mgqw.c:1359: 錯誤:『zjhsw』 未宣告 (在此函式內第一次使用)

mgqw.c:1365: 錯誤:expected expression before 『static』

mgqw.c:1366: 錯誤:『jjzxsw』 未宣告 (在此函式內第一次使用)

mgqw.c:1372: 錯誤:expected expression before 『static』

mgqw.c:1373: 錯誤:『hjcdsw』 未宣告 (在此函式內第一次使用)

mgqw.c:1379: 錯誤:expected expression before 『static』

mgqw.c:1380: 錯誤:『bbcysw』 未宣告 (在此函式內第一次使用)

mgqw.c:1386: 錯誤:expected expression before 『static』

mgqw.c:1387: 錯誤:『kymxsw』 未宣告 (在此函式內第一次使用)

mgqw.c:1392: 錯誤:expected expression before 『static』

mgqw.c:1393: 錯誤:『dqdzsw』 未宣告 (在此函式內第一次使用)

將mgqw.c檔案改名為mgqw.cc或者mgqw.cpp(表示是c++檔案)後再使用命令:

gcc mgqw.cc -o mgqw -lstdc++

程式編譯成功!花了我大半天時間才弄明白這個問題,暈死。

gcc和g 的區別

gcc和g 都是gnu 組織 的乙個編譯器。誤區一 gcc只能編譯c g 只能編譯c 兩者都可以,但是請注意 1.字尾為.c的,gcc把它當作是c程式,而g 當作是c 程式 字尾為.cpp的,兩者都會認為是c 程式,注意,雖然c 是c的超集,但是兩者對語法的要求是有區別的。c 的語法規則更加嚴謹一些...

GCC和G 的區別

gcc和g 都是gnu 組織 的乙個編譯器。誤區一 gcc只能編譯c g 只能編譯c 兩者都可以,但是請注意 1.字尾為.c的,gcc把它當作是c程式,而g 當作是c 程式 字尾為.cpp的,兩者都會認為是c 程式,注意,雖然c 是c的超集,但是兩者對語法的要求是有區別的。c 的語法規則更加嚴謹一些...

gcc和g 的區別

誤區一 gcc只能編譯c g 只能編譯c 兩者都可以,但是請注意 1.字尾為.c的,gcc把它當作是c程式,而g 當作是c 程式 字尾為.cpp的,兩者都會認為是c 程式,注意,雖然c 是c的超集,但是兩者對語法的要求是有區別的。c 的語法規則更加嚴謹一些。2.編譯階段,g 會呼叫gcc,對於c 兩...