CC是UNIX上的C語言編譯器,收費
GCC是linux上的C語言編譯器,免費,G++是C++的;為避免UNIX上的程序移植到linux上出錯,cc已經被連接到了gcc或clang上。
Clang是一個比GCC表現更優秀的C、C++、OC的編譯器,并且現在也支持GDB了。
make是一個工具,用來更好的實現多文件的編譯。
GDB是unix下的代碼調試工具。
GCC
◆ 預處理(Pre-Processing)
◆ 編譯(Compiling)
◆ 匯編(Assembling)
◆ 鏈接(Linking)
- 指定輸出可執行文件的名字
使用最基本的gcc編譯格式
gcc mian.c
執行完上面這句命令,會在當前目錄下輸出一個名為a.out的可執行文件。
使用 -o選項可以指定輸出的可執行文件名稱。
gcc main.c -o main
- 打印出編譯的警告
cc -Wall main.c -o main
- 指定 -E編譯選項,使得只輸出預編譯結果
$ gcc -E main.c > main.i
- 通過編譯選項 -S 輸出匯編代碼
gcc -S main.c > main.s
- 指定-C 輸出編譯后的代碼
gcc -C main.c
- 通過編譯選項-save-temps 輸出所有的中間代碼。
$ gcc -save-temps main.c $ ls a.out main.c main.i main.o main.s
- 鏈接共享庫(動態鏈接庫)指定編譯選項 -l
gcc -Wall main.c -o main -lCPPfile
gcc命令指出再執行鏈接main.c 代碼時,會鏈接上-lCPPfile.so動態鏈接庫來完成生成main可執行文件。 - 指定編譯選項-fPIC 創建獨立的(無關聯的)地址信息代碼。
當創建動態鏈接庫時,獨立位置信息(position independent)代碼也需要生成。這可以幫助動態鏈接庫或者跟多的加載地址信息來替代其他相對的地址信息。所以-fPIC這個選項作用很大,能快速準確定位錯誤地址。
下面是一個例子,
$ gcc -c -Wall -Werror -fPIC Cfile.c $ gcc -shared -o libCfile.so Cfile.o
- 打印輸出有個執行過程的信息 使用-V選項
$ gcc -Wall -v main.c -o main Using built-in specs. COLLECT_GCC=gcc COLLECT_LTO_WRAPPER=/usr/lib/gcc/i686-linux-gnu/4.6/lto-wrapper Target: i686-linux-gnu Configured with: ../src/configure -v --with-pkgversion='Ubuntu/Linaro 4.6.3-1ubuntu5' --with-bugurl=file:///usr/share/doc/gcc-4.6/README.Bugs --enable-languages=c,c++,fortran,objc,obj-c++ --prefix=/usr --program-suffix=-4.6 --enable-shared --enable-linker-build-id --with-system-zlib --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --with-gxx-include-dir=/usr/include/c++/4.6 --libdir=/usr/lib --enable-nls --with-sysroot=/ --enable-clocale=gnu --enable-libstdcxx-debug --enable-libstdcxx-time=yes --enable-gnu-unique-object --enable-plugin --enable-objc-gc --enable-targets=all --disable-werror --with-arch-32=i686 --with-tune=generic --enable-checking=release --build=i686-linux-gnu --host=i686-linux-gnu --target=i686-linux-gnu Thread model: posix gcc version 4.6.3 (Ubuntu/Linaro 4.6.3-1ubuntu5) ... ... ...
- 指定編譯選項-ansi,支持ISO C89 programs
#include<stdio.h>
int main(void)
{
// Print the string
printf("\n The Geek Stuff\n");
return 0;
}
執行上面代碼附加-ansi編譯選項,編譯器會輸出錯誤因為c++ 不支持ISO C89風格。
$ gcc -Wall -ansi main.c -o main main.c: In function a€?maina€?: main.c:5:3: error: expected expression before a€?/a€? token
11.指定編譯選項 -funsigned-char選項將char類型解釋為unsigned char類型。
#include<stdio.h>
int main(void)
{
char c = -10;
// Print the string
printf("\n The Geek Stuff [%d]\n", c);
return 0;
}
執行上面代碼輸出:
$ gcc -Wall -funsigned-char main.c -o main $ ./main The Geek Stuff [246]
12.指定編譯選項 -fsigned-char選項將unsigned char類型解釋為 char類型。
$ gcc -Wall -fsigned-char main.c -o main $ ./main The Geek Stuff [-10]
13.指定-D選項 開啟編譯時的宏
例子如下:
#include<stdio.h>
int main(void)
{
#ifdef MY_MACRO
printf("\n Macro defined \n");
#endif
char c = -10;
// Print the string
printf("\n The Geek Stuff [%d]\n", c);
return 0;
}
通過編譯選項 可以直接定義宏
$ gcc -Wall -DMY_MACRO main.c -o main
$ ./main
Macro defined
The Geek Stuff [-10]
14.將編譯警告轉換成錯誤.
編譯警告很多時候會被我們忽視,在特殊場合我們還是需要重視編譯警告,如果能把編譯警告變長直接輸出錯誤,那我們的重視程度會提高很多并去解決。
#include<stdio.h>
int main(void)
{
char c;
// Print the string
printf("\n The Geek Stuff [%d]\n", c);
return 0;
}
$ gcc -Wall -Werror main.c -o main main.c: In function a€?maina€?: main.c:7:10: error: a€?ca€? is used uninitialized in this function [-Werror=uninitialized] cc1: all warnings being treated as errors
上述代碼未初始化變量c,警告變成了錯誤提示.
15.通過文件指定編譯選項,指定@編譯選項
比較神奇的功能。可以使用@編譯選項然后跟著文件名,一個以上的編譯選項用空格 隔開。
$ cat opt_file -Wall -omain
$ gcc main.c @opt_file main.c: In function ‘main’: main.c:6:11: warning: ‘i’ is used uninitialized in this function [-Wuninitialized]
$ ls main main
clang
使用上和gcc差不多,搭配LLVM和gcc不一樣,目前就這樣,隨后在總結。
make
make命令執行時,需要一個 Makefile 文件,以告訴make命令需要怎么樣的去編譯和鏈接程序。