GCC和G++

來源:互聯網
上載者:User

誤區一: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,二者等價。

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 <stdio.h>

int main(int argc, char* argv[]) {

   if(argv == 0) return;

   printString(argv);

   return;

}
int printString(char* string) {

  sprintf(string, "This is a test.\n");

}

如果按照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 <iostream>

#include "me.h"

using namespace std;

void CppPrintf(void)

{

     cout << "Hello\n";

}

test.cpp:

#include <stdlib.h>

#include <stdio.h>

#include "me.h"        

int main(void)

{

    CppPrintf();

    return 0;

}

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的。-----------------先收藏一下,方便以後查閱

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.