找gcc参数网上总是不全,现在整理一下,并且不断维护,以备不时之需
捡点常用的-------------------------------------------------
gcc/g++编译过程
-> 预处理,生成.i的文件
-> 转换成汇编语言,生成文件.s文件
-> 生成.o的文件
-> 连接目标代码,生成可执行程序
[参数详解]
-c
只激活预处理,编译,和汇编,也就是他只把程序做成obj文件
例子用法:
gcc
他将生成.o的obj文件
-o
制定目标名称,缺省的时候,gcc
例子用法
gcc
-O0
-O1
-O2
-O3
编译器的优化选项的4个级别,-O0表示没有优化,-O1为缺省值,-O3优化级别最
高
只是编译器,在编译的时候,产生条是信息。
-ansi
关闭gnu
些asm
-wall
-include
包含某个代码,简单来说,就是便以某个文件,需要另一个文件的时候,就可以
用它设定,功能就相当于在代码中使用#include
例子用法:
gcc
-C
在预处理的时候,不删除注释信息,一般和-E使用,有时候分析程序,用这个很
方便的
-S
只激活预处理和编译,就是指把文件编译成为汇编代码。
例子用法
gcc
他将生成.s的汇编代码,你可以用文本编辑器察看
-E
只激活预处理,这个不生成文件,你需要把它重定向到一个输出文件里
面.
例子用法:
gcc
gcc
慢慢看吧,一个hello
-D
宏定义
例如:
gcc
相当于在hello.c内添加#define _DEBUG
-U
宏定义
例如:
gcc
相当于在hello.c内添加#undef
-I
在你是用#include"file"的时候,gcc/g++会先在当前目录查找你所制定的头
文件,如果没有找到,他回到缺省的头文件目录找,如果使用-I制定了目录,他
回先在你所制定的目录查找,然后再按常规的顺序去找.
对于#include,gcc/g++会到-I制定的目录查找,查找不到,然后将到系
统的缺省的头文件目录查找
例如
gcc
这样会去$(HOME)/hello查找头文件
-I-
就是取消前一个参数的功能,所以一般在-Idir之后使用
-idirafter
在-I的目录里面查找失败,讲到这个目录里面查找.
-iprefix
-iwithprefix
一般一起使用,当-I的目录查找失败,会到prefix+dir下查找
-nostdinc
使编译器不再系统缺省的头文件目录里面找头文件,一般和-I联合使用,明确
限定头文件的位置
-nostdin
规定不在g++指定的标准路经中搜索,但仍在其他路径中搜索,.此选项在创建
libg++库使用
-M
生成文件关联的信息。包含目标文件所依赖的所有源代码
你可以用gcc
-MM
和上面的那个一样,但是它将忽略由#include造成的依赖关系。
-MD
和-M相同,但是输出将导入到.d的文件里面
-MMD
和-MM相同,但是输出将导入到.d的文件里面
-Wa,option
此选项传递option给汇编程序;如果option中间有逗号,就将option分成多个选
项,然后传递给会汇编程序
-Wl.option
此选项传递option给连接程序;如果option中间有逗号,就将option分成多个选
项,然后传递给会连接程序.
-l
例子用法
libtest.so,那么我们只要把libtest.so拷贝到放在/lib和/usr/lib和/usr/local/lib里,编译时加上-ltest参数,我们就能用 上libtest.so库
-L
如果/lib和/usr/lib和/usr/local/lib里,而是放在其他目录里,这时我们只用-l参数的话,链接还是会出错,出错信息大概 是:“/usr/bin/ld: cannot find -lxxx”,也就是链接程序ld在那3个目录里找不到libxxx.so,这时参数-L就派上用场了, 比如常用的X11的库,它在/usr/X11R6/lib目录下,我们编译时就要用-L/usr/X11R6/lib -lX11参数,-L参数跟着的是库文件所 在的目录名。再比如我们把libtest.so放在/aaa/bbb/ccc目录下,那链接参数就是-L/aaa/bbb/ccc -ltest。
-gstabs
此选项以stabs格式声称调试信息,但是不包括gdb调试信息.
-gstabs+
此选项以stabs格式声称调试信息,并且包含仅供gdb使用的额外调试信息.
-ggdb
此选项将尽可能的生成gdb的可以使用的调试信息.