c編譯器怎麼擴展
2004年4月20日最新版本的GCC編譯器3.4.0發布了。目前,GCC可以用來編譯C/C++、FORTRAN、java、OBJC、ADA等語言的程序,可根據需要選擇安裝支持的語言。GCC 3.4.0比以前版本更好地支持了C++標准。本文以在Redhat Linux上安裝GCC3.4.0為例,介紹了GCC的安裝過程。
安裝之前,系統中必須要有cc或者gcc等編譯器,並且是可用的,或者用環境變數CC指定系統上的編譯器。如果系統上沒有編譯器,不能安裝源代碼形式的GCC 3.4.0。如果是這種情況,可以在網上找一個與你系統相適應的如RPM等二進制形式的GCC軟體包來安裝使用。本文介紹的是以源代碼形式提供的GCC軟體包的安裝過程,軟體包本身和其安裝過程同樣適用於其它Linux和Unix系統。
系統上原來的GCC編譯器可能是把gcc等命令文件、庫文件、頭文件等分別存放到系統中的不同目錄下的。與此不同,現在GCC建議我們將一個版本的GCC安裝在一個單獨的目錄下。這樣做的好處是將來不需要它的時候可以方便地刪除整個目錄即可(因為GCC沒有uninstall功能);缺點是在安裝完成後要做一些設置工作才能使編譯器工作正常。在本文中我採用這個方案安裝GCC 3.4.0,並且在安裝完成後,仍然能夠使用原來低版本的GCC編譯器,即一個系統上可以同時存在並使用多個版本的GCC編譯器。
按照本文提供的步驟和設置選項,即使以前沒有安裝過GCC,也可以在系統上安裝上一個可工作的新版本的GCC編譯器。
1. 下載
在GCC網站上( http://gcc.gnu.org/)或者通過網上搜索可以查找到下載資源。目前GCC的最新版本為 3.4.0。可供下載的文件一般有兩種形式:gcc-3.4.0.tar.gz和gcc-3.4.0.tar.bz2,只是壓縮格式不一樣,內容完全一致,下載其中一種即可。
2. 解壓縮
根據壓縮格式,選擇下面相應的一種方式解包(以下的「%」表示命令行提示符):
% tar xzvf gcc-3.4.0.tar.gz
或者
% bzcat gcc-3.4.0.tar.bz2 | tar xvf -
新生成的gcc-3.4.0這個目錄被稱為源目錄,用${srcdir}表示它。以後在出現${srcdir}的地方,應該用真實的路徑來替換它。用pwd命令可以查看當前路徑。
在${srcdir}/INSTALL目錄下有詳細的GCC安裝說明,可用瀏覽器打開index.html閱讀。
3. 建立目標目錄
目標目錄(用${objdir}表示)是用來存放編譯結果的地方。GCC建議編譯後的文件不要放在源目錄${srcdir]中(雖然這樣做也可以),最好單獨存放在另外一個目錄中,而且不能是${srcdir}的子目錄。
例如,可以這樣建立一個叫 gcc-build 的目標目錄(與源目錄${srcdir}是同級目錄):
% mkdir gcc-build
% cd gcc-build
以下的操作主要是在目標目錄 ${objdir} 下進行。
4. 配置
配置的目的是決定將GCC編譯器安裝到什麼地方(${destdir}),支持什麼語言以及指定其它一些選項等。其中,${destdir}不能與${objdir}或${srcdir}目錄相同。
配置是通過執行${srcdir}下的configure來完成的。其命令格式為(記得用你的真實路徑替換${destdir}):
% ${srcdir}/configure --prefix=${destdir} [其它選項]
例如,如果想將GCC 3.4.0安裝到/usr/local/gcc-3.4.0目錄下,則${destdir}就表示這個路徑。
在我的機器上,我是這樣配置的:
% ../gcc-3.4.0/configure --prefix=/usr/local/gcc-3.4.0 --enable-threads=posix --disable-checking --enable--long-long --host=i386-redhat-linux --with-system-zlib --enable-languages=c,c++,java
將GCC安裝在/usr/local/gcc-3.4.0目錄下,支持C/C++和JAVA語言,其它選項參見GCC提供的幫助說明。
5. 編譯
% make
這是一個漫長的過程。在我的機器上(P4-1.6),這個過程用了50多分鍾。
6. 安裝
執行下面的命令將編譯好的庫文件等拷貝到${destdir}目錄中(根據你設定的路徑,可能需要管理員的許可權):
% make install
至此,GCC 3.4.0安裝過程就完成了。
6. 其它設置
GCC 3.4.0的所有文件,包括命令文件(如gcc、g++)、庫文件等都在${destdir}目錄下分別存放,如命令文件放在bin目錄下、庫文件在lib下、頭文件在include下等。由於命令文件和庫文件所在的目錄還沒有包含在相應的搜索路徑內,所以必須要作適當的設置之後編譯器才能順利地找到並使用它們。
6.1 gcc、g++、gcj的設置
要想使用GCC 3.4.0的gcc等命令,簡單的方法就是把它的路徑${destdir}/bin放在環境變數PATH中。我不用這種方式,而是用符號連接的方式實現,這樣做的好處是我仍然可以使用系統上原來的舊版本的GCC編譯器。
首先,查看原來的gcc所在的路徑:
% which gcc
在我的系統上,上述命令顯示:/usr/bin/gcc。因此,原來的gcc命令在/usr/bin目錄下。我們可以把GCC 3.4.0中的gcc、g++、gcj等命令在/usr/bin目錄下分別做一個符號連接:
% cd /usr/bin
% ln -s ${destdir}/bin/gcc gcc34
% ln -s ${destdir}/bin/g++ g++34
% ln -s ${destdir}/bin/gcj gcj34
這樣,就可以分別使用gcc34、g++34、gcj34來調用GCC 3.4.0的gcc、g++、gcj完成對C、C++、JAVA程序的編譯了。同時,仍然能夠使用舊版本的GCC編譯器中的gcc、g++等命令。
6.2 庫路徑的設置
將${destdir}/lib路徑添加到環境變數LD_LIBRARY_PATH中,最好添加到系統的配置文件中,這樣就不必要每次都設置這個環境變數了。
例如,如果GCC 3.4.0安裝在/usr/local/gcc-3.4.0目錄下,在RH Linux下可以直接在命令行上執行或者在文件/etc/profile中添加下面一句:
setenv LD_LIBRARY_PATH /usr/local/gcc-3.4.0/lib:$LD_LIBRARY_PATH
7. 測試
用新的編譯命令(gcc34、g++34等)編譯你以前的C、C++程序,檢驗新安裝的GCC編譯器是否能正常工作。
8. 根據需要,可以刪除或者保留${srcdir}和${objdir}目錄。
『貳』 c語言編譯器的功能
目前最流行的C語言編譯器有以下幾種:
·GNU Compiler Collection 或稱 GCC
·Microsoft C 或稱 MS C
·Borland Turbo C 或稱 Turbo C
這些C語言版本不僅實現了ANSI C標准,而且在此基礎上各自作了一些擴充,使之更加方便、完美。
『叄』 c語言編譯器如何運行
編譯共分為四個階段:預處理階段、編譯階段、匯編階段、鏈接階段。
1、預處理階段:
主要工作是將頭文件插入到所寫的代碼中,生成擴展名為「.i」的文件替換原來的擴展名為「.c」的文件,但是原來的文件仍然保留,只是執行過程中的實際文件發生了改變。(這里所說的替換並不是指原來的文件被刪除)
2、匯編階段:
插入匯編語言程序,將代碼翻譯成匯編語言。編譯器首先要檢查代碼的規范性、是否有語法錯誤等,以確定代碼的實際要做的工作,在檢查無誤後,編譯器把代碼翻譯成匯編語言,同時將擴展名為「.i」的文件翻譯成擴展名為「.s」的文件。
3、編譯階段:
將匯編語言翻譯成機器語言指令,並將指令打包封存成可重定位目標程序的格式,將擴展名為「.s」的文件翻譯成擴展名為「.o」的二進制文件。
4、鏈接階段:
在示例代碼中,改代碼文件調用了標准庫中printf函數。而printf函數的實際存儲位置是一個單獨編譯的目標文件(編譯的結果也是擴展名為「.o」的文件),所以此時主函數調用的時候,需要將該文件(即printf函數所在的編譯文件)與hello world文件整合到一起,此時鏈接器就可以大顯神通了,將兩個文件合並後生成一個可執行目標文件。
『肆』 C,編譯器問題
前三個Warning在說"-std=gnu99、-std=c99、-std=c89"這三個東西是用來搞C語言或者ObjC語言的,所以你是不是程序保存的時候後綴存成cpp而不是c了?(前者是c++語言程序文件後綴名,後者是C語言)
最後一個Error解決辦法:在菜單欄以此單擊"Build"→「Bulid Options」彈出一個對話框,在Category那有個下拉列表的(默認好像是C++ Language),點擊選擇C Lanuage。然後緊接著下面有五個小鉤鉤,去掉最後一個。(或者把Raw Options下面那個框里的-fallow-single-precision刪掉,是一樣的。)點擊OK,完成。
『伍』 如何使用c語言編譯器
得先以你下載的那個編譯器把 11.c 編譯了, 生成執行文件, 再在cmd中運行這個執行文件.
『陸』 c語言的宏擴展指什麼
簡單來說:宏定義又稱為宏代換、宏替換,簡稱「宏」。是C提供的三種預處理功能的其中一種。
復雜的請看下面,講的很全。下面的帶參宏定義,多行宏定義,在Linux內核源碼中很多。另外sizeof也是一個宏定義。
宏定義
宏定義是C提供的三種預處理功能的其中一種,這三種預處理包括:宏定義、文件包含、條件編譯
1. 不帶參數的宏定義:
宏定義又稱為宏代換、宏替換,簡稱「宏」。
格式: #define 標識符 字元串
其中的標識符就是所謂的符號常量,也稱為「宏名」。
預處理(預編譯)工作也叫做宏展開:將宏名替換為字元串。
掌握"宏"概念的關鍵是「換」。一切以換為前提、做任何事情之前先要換,准確理解之前就要「換」。
即在對相關命令或語句的含義和功能作具體分析之前就要換:
例: #define PI 3.1415926 把程序中出現的PI全部換成3.1415926
說明:
(1)宏名一般用大寫
(2)使用宏可提高程序的通用性和易讀性,減少不一致性,減少輸入錯誤和便於修改。例如:數組大小常用宏定義
(3)預處理是在編譯之前的處理,而編譯工作的任務之一就是語法檢查,預處理不做語法檢查。
(4)宏定義末尾不加分號;
(5)宏定義寫在函數的花括弧外邊,作用域為其後的程序,通常在文件的最開頭。
(6)可以用#undef命令終止宏定義的作用域
(7)宏定義可以嵌套
(8)字元串" "中永遠不包含宏
(9)宏定義不分配內存,變數定義分配內存。
2. 帶參數的宏定義:
除了一般的字元串替換,還要做參數代換
格式: #define 宏名(參數表) 字元串
例如:#define S(a,b) a*b
area=S(3,2);第一步被換為area=a*b; ,第二步被換為area=3*2;
類似於函數調用,有一個啞實結合的過程:
(1)實參如果是表達式容易出問題
#define S(r) r*r
area=S(a+b);第一步換為area=r*r;,第二步被換為area=a+b*a+b;
正確的宏定義是#define S(r) ((r)*(r))
(2)宏名和參數的括弧間不能有空格
(3)宏替換只作替換,不做計算,不做表達式求解
(4)函數調用在編譯後程序運行時進行,並且分配內存。宏替換在編譯前進行,不分配內存
(5)宏的啞實結合不存在類型,也沒有類型轉換。
(6)函數只有一個返回值,利用宏則可以設法得到多個值
(7)宏展開使源程序變長,函數調用不會
(8)宏展開不佔運行時間,只佔編譯時間,函數調用占運行時間(分配內存、保留現場、值傳遞、返回值)
3. 宏定義其他冷門、重點知識
#define用法
1、 用無參宏定義一個簡單的常量
#define LEN 12
這個是最常見的用法,但也會出錯。
比如下面幾個知識點你會嗎?可以看下:
(1) #define NAME "zhangyuncong"
程序中有"NAME"則,它會不會被替換呢?
(2) #define 0x abcd
可以嗎?也就是說,可不可以用把標識符的字母替換成別的東西?
(3) #define NAME "zhang
這個可以嗎?
(4) #define NAME "zhangyuncong"
程序中有上面的宏定義,並且,程序里有句:
NAMELIST這樣,會不會被替換成"zhangyuncong"LIST
四個題答案都是否定的。
第一個,""內的東西不會被宏替換。這一點應該大都知道。
第二個,宏定義前面的那個必須是合法的用戶標識符
第三個,宏定義也不是說後面東西隨便寫,不能把字元串的兩個""拆開。
第四個:只替換標識符,不替換別的東西。NAMELIST整體是個標識符,而沒有NAME標識符,所以不替換。
也就是說,這種情況下記住:#define 第一位置第二位置
(1) 不替換程序中字元串里的東西。
(2) 第一位置只能是合法的標識符(可以是關鍵字)
(3) 第二位置如果有字元串,必須把""配對。
(4) 只替換與第一位置完全相同的標識符
還有就是老生常談的話:記住這是簡單的替換而已,不要在中間計算結果,一定要替換出表達式之後再算。
2、 帶參宏一般用法
比如#define MAX(a,b) ((a)>(b)?(a):(b))
則遇到MAX(1+2,value)則會把它替換成:
((1+2)>(value)?(1+2):(value))
注意事項和無參宏差不多。
但還是應注意
#define FUN(a) "a"
則,輸入FUN(345)會被替換成什麼?
其實,如果這么寫,無論宏的實參是什麼,都不會影響其被替換成"a"的命運。
也就是說,""內的字元不被當成形參,即使它和一模一樣。
那麼,你會問了,我要是想讓這里輸入FUN(345)它就替換成"345"該怎麼實現呢?
請看下面關於#的用法
3、 有參宏定義中#的用法
#define STR(str) #str
#用於把宏定義中的參數兩端加上字元串的""
比如,這里STR(my#name)會被替換成"my#name"
一般由任意字元都可以做形參,但以下情況會出錯:
STR())這樣,編譯器不會把「)」當成STR()的參數。
STR(,)同上,編譯器不會把「,」當成STR的參數。
STR(A,B)如果實參過多,則編譯器會把多餘的參數捨去。(VC++2008為例)
STR((A,B))會被解讀為實參為:(A,B),而不是被解讀為兩個實參,第一個是(A第二個是B)。 4、 有參宏定義中##的用法
#define WIDE(str) L##str
則會將形參str的前面加上L
比如:WIDE("abc")就會被替換成L"abc"
如果有#define FUN(a,b) vo##a##b()
那麼FUN(id ma,in)會被替換成void main()
5、 多行宏定義:
#define doit(m,n) for(int i=0;i<(n);++i)\
{\
m+=i;\
}
『柒』 TKstudi C編譯器怎麼設置
VC就很了不起,因為使用這樣傻瓜化的工具只能讓你看不到事物的本質。接下來我們就來深入的認識Turbo C編譯器。 廣義的編譯器,包括了代碼編譯器(compiler),目標文件鏈接器(linker),庫文件管理工具(如tc的tlib,gcc的ar),編譯驅動工具(如VC的NMake,gcc的make),ANSI c/c++標準的頭文件和庫文件,擴展的頭文件和庫文件,集成開發環境(IDE),等等與編譯相關的工具,所有這些工具的集合,就組成了廣義上的編譯器。
狹義的編譯器,則僅指compiler。compiler只負責將源代碼,即.c/.cxx/.cpp文件編譯成為目標文件.o/.obj。編譯過程的輸入是源文件,包括自己書寫的.c和.h以及系統提供的.h文件,編譯的輸出是目標文件。需要強調的一點時,在compile階段,只處理源文件,所以不需要庫文件和額外的目標文件的參與,因此,只要代碼在語法上沒有錯誤,compile就一定能產生目標文件。
對於一個廣義的編譯器來說以下幾個部分是必備的:1.compiler,2.linker,3.系統提供的頭文件和庫文件。前面已經介紹了compiler,接下來看linker。
linker的功能是將目標文件進行裝配,將浮動的地址變為確定的地址,這個工作是通過修改目標文件的重定位項來實現的,其具體的過程可以參考"Linker & loader"這本書,這是一本詳細介紹linker和loader的好書,在此做個推薦。總之,link這一階段處理的輸入是目標文件,其輸出是可執行文件,或動態庫。
任何一個編譯器都會提供庫文件和與之對應的頭文件,C/C++編譯器一般都提供ANSI C/C++的庫和相應的頭文件。
從現在起我們就需要建立起一個概念,就是廣義的編譯過程,實際上是由編譯和鏈接兩個基本步驟組成的,如果能深刻的理解這兩個步驟,就是一大進步了。
在編譯器里,有一些默認的規定,我們需要了解。在編譯器中,bin目錄用於存放compiler、linker等工具,include目錄用於存放頭文件,lib目錄用存放庫文件,大多數的編譯器的目錄就是按這個來組織的。
接下來看Turbo C為我們提供了些什麼
bin目錄中:
CPP.EXE 是一個C語言預處理工具,就是負責對源代碼進行預編譯處理,不要理解為c++編譯器
TCC.EXE 是一個C語言的編譯器,可以將代碼編譯為目標文件,並且能自動調用tlink鏈接生成可執行文件
TASM.exe 是一個匯編工具,可以將x86的匯編代碼編譯成為目標文件
TLink.exe 是一個鏈接器,負責對目標文件、庫文件等進行鏈接
TLib.exe 是一個庫文件管理工具,可以將多個目標文件打包到一個庫文件里
BGIOBJ.exe 可以將BGI文件轉換為.obj文件
make.exe 符合GNU標準的make工具,可用於代碼編譯的管理
TURBOC.CFG tcc默認的編譯參數配置文件
以上所有的工具的使用方法都可以直接鍵入相應的命令進行查看,如鍵入tcc即可看到tcc的使用方法,因此這里不再講解。
BGI目錄中:
EGAVGA.BGI 是EGAVGA的bgi驅動
FONT目錄中:存放了BGI所使用到的各種字體文件
INCLUDE目錄中:是Turbo C的庫函數的所有的頭文件,當要使用某個庫函數時可以在這個目錄下搜索,找到其所在文件和原型,這里不在詳細敘述。
重點講一下Lib目錄:
init.obj文件是C語言的啟動代碼,它負責建立C程序運行的堆棧、初始化內存、調用C入口函數等。這部分代碼是使用匯編書寫的,其源代碼可以在TC(官方版)里找到,名稱為Init.ASM。
c0t.obj、c0s.obj、c0m.obj、c0c.obj、c0l.obj和c0h.obj文件,都是c code的入口函數實現,入口函數將會讀取環境變數,並調用c語言中的main函數,將命令行參數傳入main函數中,之後的控制權就交給了main函數,也就是我們常說的C的主函數main。由於Turbo C中有不同的內存模式,因此以上6個文件分別對應TC中6種不同的內存模式。
cc.lib、ch.lib、cl.lib、cm.lib、cs.lib五個文件都是TC提供的ANSI C標准庫的庫文件,分別對用不同的內存模式:
cc compact模式
ch huge模式
cl large模式
cm medium模式
cs small模式
『捌』 window內自帶的C語言編譯器怎麼用
1、首先,輸入【#include】。
注意事項:
盡管C語言提供了許多低級處理的功能,但仍然保持著跨平台的特性,以一個標准規格寫出的C語言程序可在包括類似嵌入式處理器以及超級計算機等作業平台的許多計算機平台上進行編譯。
『玖』 c語言 怎麼在CMD下運行編譯器,想查看擴展後的宏,
cl source_file。如果不能使用這個命令可能是沒有設置路徑。搜索出來路徑添加就好了。至於命令中定義宏我不清楚。linux中是gcc -g -o resultname -Ddefinename='' sourcefile 。其中-g是調用調試器,-o是定義編譯後生成的可執行性文件名,如果沒有此選項會生成名為a.out的文件。-D命令是定義宏,引號中是宏的內容。最後要加上源文件的名字。linux中還有很多工具編寫程序。如果你喜歡使用命令行可以試試linux,你會發現它很有趣
『拾』 window內自帶的C語言編譯器怎麼用
1。turbo c 比較實用的編譯器
按f10,用方向鍵選擇最左邊file,點回車鍵出現下拉菜單,選擇第一個,把裡面的內容全刪瞭然後輸入x:\(x為源文件所在盤),找到源文件,回車鍵打開。
然後再按f10,選擇run或單擊r運行,或者直接按f9編譯,編譯後的文件在turbo c 所在文件夾的 out put文件夾裡面。
2。visual c++事實上這不只是單純的編譯器,應該說是開發環境,但包含有編譯功能,直接滑鼠操作就可以了。