gcc與g編譯器的區別
Ⅰ GCC、G++與C、C++代表的含義與區別
C和C++都指的是語言。
GCC則指的是一種編譯器集合,GNU Compiler Collections,支持編譯多種語言。不過現在有很多人將其誤禪殲解為GNU的C編譯器。。(比如很多ACM的OJ中,語言選GCC就意味著將代碼作為.C文件編譯)
G++就是GCC這個編譯器集合中的C++編譯器。有時候也被泛指為符合GNU C++編譯器標準的C++代碼。總之你在OJ中要交C++代碼念襲譽的話選仔段它就ok了。
現在明白了吧,呵呵。
Ⅱ Linux下gcc/g++,make和cmake的區別
gcc是一個c語言編譯器,g++是一個C++語言的編譯器,這是它們的主要區別,雖然說gcc也可以編譯C++代碼文件,但實際上是需要g++支持的,gcc編譯C++時是要調用g++的。
make是根據Makefile中定義的編譯規則來對多個源文件執行編譯命令,也就是說它是管理編譯規則的工具,並不實際編譯文件;而cmake則是可以生成Makefile文件的一個工具,實際上,cmake工具不僅可以生成Makefile,還可以生成Windows平台的VS等開發工具的dsp等工程文件,這樣管理項目就更方便了。
Ⅲ gcc編譯器和g++編譯器的區別
對於.c文件gcc當做c語言處理,g++當做c++處理;對於.cpp文件gcc和g++均當做c++處理;
g++編譯時實際上是調用gcc進行編譯;
gcc不能自動鏈接庫文件,一般用g++來鏈接庫文件,非要用gcc的話,一般使用gcc -lstdc++命令;
extern 「c」對於gcc和g++沒有區別;
實際使用時只需安裝gcc和g++中的一個就行了,如果使用gcc,編譯直接用gcc就行了,鏈接要加上-lstdc++參數;如果使用g++,編譯時實際還是調用gcc,鏈接直接使用g++即可;
關於包含庫文件頭文件的說明:以gtd庫文件為例,庫文件一般是libgtd.so格式的文件,如果是libgtd-***.so或者其他格式,可以通過軟鏈接命令轉化成libgtd.so格式,ln
-s libgtd-***.so
libgtd.so。一般庫文件如果是放在/lib,/usr/lib,/usr/local/lib目錄下,則無需額外處理,編譯鏈接時-lgtd會自動找到對應文件不會報錯,但是如果不在對應目錄,則需要加上-L
/所在目錄
-lgtd才能找到對應的庫文件。頭文件一般是採用源文件中用#include命令包含,而不是採用-include參數包含,頭文件如果放在/usr/include目錄下則會自動找到不會報錯,否則編譯鏈接時需要使用-I
/所在目錄才能正確找到。
編譯鏈接命令示例:
g++ test.cpp -o test.txt -L /mytest/lib -lgtd -I /mytest/include
Ⅳ GCC編譯器和G++編譯器的區別
按照c的寫法 第褲逗宏二個NodeTrie *p應當寫成struct NodeTrie *p,按照指冊c++的寫法實際不需要typedef了,struct與class的唯一區別就是成員變數前者默認public後者默認private 。
c的語法在NodeTrie *p這個時候 由於還沒走到右花括弧那個NodeTrie ,也就是說typedef還沒有完成,那麼自然他不認識NodeTrie 這是什麼東西,只認識胡冊struct NodeTrie
Ⅳ g++編譯器和gcc編譯器的不同。gcc只能編譯C程么 C++程序用gcc編譯器編譯時報錯。
UNIX/LINUX中,C++ 的程序,是用g++編譯的,飢悄不同的編譯器燃滾編譯不同類型的文件,gcc是皮肢余對應C程序的編譯器。
Ⅵ 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的。
Ⅶ G++和GCC和C,C++有什麼區別的
G++和C++都是C++語言的編譯器,二者基寬襲本相同。而GCC和C都是C語言編譯器,而這差別實際也不大。盡管C++規范中兼容絕大部分C的用法和幾乎全部函數,但畢竟還是有更改的地方。記住,如果你在學C或C++,不要過於遷就編譯器的差別!研究語言比研慎輪兄究編譯器(或編譯環境)桐基要重要的多!
Ⅷ c語言編譯器與gcc與g++的區別是什麼 為什麼在VC中編譯錯誤在gcc中就能通過 北大的acm網站上的1007題。
gcc是C語言編譯器個,g++是C++語言編譯器。
VC既有C語言編譯器(當擴展名為.c的時候),又有C++語言編譯器(當擴展名為.cpp的時候)。
C語言不允許在可執行語句後定義納歲早變數,可是C++允許。
你在scanf("%d%d",&m,&n);後面定義了int i;這違反了C語洞雀言的語法,但符合C++的語雀中法。
Ⅸ G++、GCC和C語言有區別嗎
誤區一: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
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
#include "me.h"
using namespace std;
void CppPrintf(void)
{
cout << "Hello\n";
}
test.cpp:
#include
#include
#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的。
Ⅹ 跪求vs、vc和GCC、G++3.4.1的具體區別
1、GCC是一個編譯器集合, VC是MS開發的Windows系統C/C++ IDE. 2、GCC中的C/C++標准庫代碼和VC肯定是不同的, MS一般都是從別人那買來用, 比如Dinkumware, GCC C/C++的標准庫就是GNU自己寫的了, 當然這遵循GPL, MS雖然也可以免費拿來用, 但是MS歷來仇視GPL和Linux. 還有就是GCC C/C++的標准庫對C/C++標準的貌似是最好的. 3、Linux的桌面操作系統基本都集成安裝了KDE(K Desktop Environment), X-Windows等圖形操作系統界面, 所以各種包裝了GCC編譯器內核的IDE應運而生, 比如Ubuntu, Mandriva, Fedora, Debian等操作系統中都有自帶的GCC IDE, 當然你也可以用Commond Line來操作和編譯代碼.