新聞中心
GCC 編譯器是 Linux 系統(tǒng)下最常用的 C/C++ 編譯器,大部分 Linux 發(fā)行版中都會默認安裝。GCC 編譯器通常以gcc命令的形式在終端(Shell)中使用,它有很多選項,這是我們要重點學習的,下面為大家講解一下Linux下GCC常用命令。

創(chuàng)新互聯(lián)是專業(yè)的焉耆網(wǎng)站建設公司,焉耆接單;提供成都網(wǎng)站建設、做網(wǎng)站,網(wǎng)頁設計,網(wǎng)站設計,建網(wǎng)站,PHP網(wǎng)站建設等專業(yè)做網(wǎng)站服務;采用PHP框架,可快速的進行焉耆網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團隊,希望更多企業(yè)前來合作!
簡單編譯
示例程序如下:
//test.c
#include
int main(void)
{
printf("Hello World!\n");
return 0;
}
這個程序,一步到位的編譯指令是:
gcc test.c -o test
實質上,上述編譯過程是分為四個階段進行的,即預處理(也稱預編譯,Preprocessing)、編譯(Compilation)、匯編 (Assembly)和連接(Linking)。
預處理
gcc -E test.c -o test.i 或 gcc -E test.c
可以輸出test.i文件中存放著test.c經(jīng)預處理之后的代碼。打開test.i文件,看一看,就明白了。后面那條指令,是直接在命令行窗口中輸出預處理后的代碼.
gcc的-E選項,可以讓編譯器在預處理后停止,并輸出預處理結果。在本例中,預處理結果就是將stdio.h 文件中的內(nèi)容插入到test.c中了。
編譯為匯編代碼(Compilation)
預處理之后,可直接對生成的test.i文件編譯,生成匯編代碼:
gcc -S test.i -o test.s
gcc的-S選項,表示在程序編譯期間,在生成匯編代碼后,停止,-o輸出匯編代碼文件。
匯編(Assembly)
對于上一小節(jié)中生成的匯編代碼文件test.s,gas匯編器負責將其編譯為目標文件,如下:
gcc -c test.s -o test.o
連接(Linking)
gcc連接器是gas提供的,負責將程序的目標文件與所需的所有附加的目標文件連接起來,最終生成可執(zhí)行文件。附加的目標文件包括靜態(tài)連接庫和動態(tài)連接庫。
對于上一小節(jié)中生成的test.o,將其與C標準輸入輸出庫進行連接,最終生成程序test
gcc test.o -o test
在命令行窗口中,執(zhí)行./test, 讓它說HelloWorld吧!
多個程序文件的編譯
通常整個程序是由多個源文件組成的,相應地也就形成了多個編譯單元,使用GCC能夠很好地管理這些編譯單元。假設有一個由test1.c和 test2.c兩個源文件組成的程序,為了對它們進行編譯,并最終生成可執(zhí)行程序test,可以使用下面這條命令:
gcc test1.c test2.c -o test
如果同時處理的文件不止一個,GCC仍然會按照預處理、編譯和鏈接的過程依次進行。如果深究起來,上面這條命令大致相當于依次執(zhí)行如下三條命令:
gcc -c test1.c -o test1.o
gcc -c test2.c -o test2.o
gcc test1.o test2.o -o test
檢錯
gcc -pedantic illcode.c -o illcode
-pedantic編譯選項并不能保證被編譯程序與ANSI/ISO C標準的完全兼容,它僅僅只能用來幫助Linux程序員離這個目標越來越近?;蛘邠Q句話說,-pedantic選項能夠幫助程序員發(fā)現(xiàn)一些不符合 ANSI/ISO C標準的代碼,但不是全部,事實上只有ANSI/ISO C語言標準中要求進行編譯器診斷的那些情況,才有可能被GCC發(fā)現(xiàn)并提出警告。
除了-pedantic之外,GCC還有一些其它編譯選項也能夠產(chǎn)生有用的警告信息。這些選項大多以-W開頭,其中最有價值的當數(shù)-Wall了,使用它能夠使GCC產(chǎn)生盡可能多的警告信息。
gcc -Wall illcode.c -o illcode
GCC給出的警告信息雖然從嚴格意義上說不能算作錯誤,但卻很可能成為錯誤的棲身之所。一個優(yōu)秀的Linux程序員應該盡量避免產(chǎn)生警告信息,使自己的代碼始終保持標準、健壯的特性。所以將警告信息當成編碼錯誤來對待,是一種值得贊揚的行為!所以,在編譯程序時帶上-Werror選項,那么GCC會在所有產(chǎn)生警告的地方停止編譯,迫使程序員對自己的代碼進行修改,如下:
gcc -Werror test.c -o test
庫文件連接
開發(fā)軟件時,完全不使用第三方函數(shù)庫的情況是比較少見的,通常來講都需要借助許多函數(shù)庫的支持才能夠完成相應的功能。從程序員的角度看,函數(shù)庫實際上就是一些頭文件(.h)和庫文件(so、或lib、dll)的集合。。雖然Linux下的大多數(shù)函數(shù)都默認將頭文件放到/usr/include/目錄下,而庫文件則放到/usr/lib/目錄下;Windows所使用的庫文件主要放在Visual Stido的目錄下的include和lib,以及系統(tǒng)文件夾下。但也有的時候,我們要用的庫不再這些目錄下,所以GCC在編譯時必須用自己的辦法來查找所需要的頭文件和庫文件。
例如我們的程序test.c是在linux上使用c連接mysql,這個時候我們需要去mysql官網(wǎng)下載MySQL Connectors的C庫,下載下來解壓之后,有一個include文件夾,里面包含mysql connectors的頭文件,還有一個lib文件夾,里面包含二進制so文件libmysqlclient.so
其中inclulde文件夾的路徑是/usr/dev/mysql/include,lib文件夾是/usr/dev/mysql/lib
編譯成可執(zhí)行文件
首先我們要進行編譯test.c為目標文件,這個時候需要執(zhí)行
gcc –c –I /usr/dev/mysql/include test.c –o test.o
鏈接
最后我們把所有目標文件鏈接成可執(zhí)行文件:
gcc –L /usr/dev/mysql/lib –lmysqlclient test.o –o test
Linux下的庫文件分為兩大類分別是動態(tài)鏈接庫(通常以.so結尾)和靜態(tài)鏈接庫(通常以.a結尾),二者的區(qū)別僅在于程序執(zhí)行時所需的代碼是在運行時動態(tài)加載的,還是在編譯時靜態(tài)加載的。
強制鏈接時使用靜態(tài)鏈接庫
默認情況下, GCC在鏈接時優(yōu)先使用動態(tài)鏈接庫,只有當動態(tài)鏈接庫不存在時才考慮使用靜態(tài)鏈接庫,如果需要的話可以在編譯時加上-static選項,強制使用靜態(tài)鏈接庫。
在/usr/dev/mysql/lib目錄下有鏈接時所需要的庫文件libmysqlclient.so和libmysqlclient.a,為了讓GCC在鏈接時只用到靜態(tài)鏈接庫,可以使用下面的命令:
gcc –L /usr/dev/mysql/lib –static –lmysqlclient test.o –o test
靜態(tài)庫鏈接時搜索路徑順序:
\1. ld會去找GCC命令中的參數(shù)-L \2. 再找gcc的環(huán)境變量LIBRARY_PATH \3. 再找內(nèi)定目錄 /lib /usr/lib /usr/local/lib 這是當初compile gcc時寫在程序內(nèi)的
動態(tài)鏈接時、執(zhí)行時搜索路徑順序:
\1. 編譯目標代碼時指定的動態(tài)庫搜索路徑 \2. 環(huán)境變量LD_LIBRARY_PATH指定的動態(tài)庫搜索路徑 \3. 配置文件/etc/ld.so.conf中指定的動態(tài)庫搜索路徑 \4. 默認的動態(tài)庫搜索路徑/lib \5. 默認的動態(tài)庫搜索路徑/usr/lib
有關環(huán)境變量: LIBRARY_PATH環(huán)境變量:指定程序靜態(tài)鏈接庫文件搜索路徑 LD_LIBRARY_PATH環(huán)境變量:指定程序動態(tài)鏈接庫文件搜索路徑
網(wǎng)站欄目:詳解GCC常用命令
轉載源于:http://www.5511xx.com/article/cdsoohs.html


咨詢
建站咨詢
