辛星整理Linux下常用的gcc参数

        首先说一下gcc和g++分别是gnu的c和c++编译器,而且它们在进行编译的时候,一般需要分为四步:

         ①预处理,对于cpp会生成.i文件,使用预处理器cpp

         ②将预处理后的文件不转换为汇编语言,生成.s文件,使用编译器egcs

         ③将汇编文件变成目标文件,也就是生成机器码,这里就是生成.o文件,使用汇编器as

         ④连接目标代码,生成可执行程序,使用连接器ld

         其中主要参数为:

          -x   language   filename它是设定文件使用的语言,此时后缀名是无效的,虽然我们约定c语言的后缀是.c,c++语言的后缀名是.cpp,但是此时我们可以随意使用后缀名。通常可用的参数有:c、objective-c、c-header、c++、cpp-output、assembler、assembler-with-cpp。比如我们可以使用命令cpp   -x  c    hello.xin

        -x    none   filename   它是关闭上一个选项,让gcc根据文件名的后缀自动判断文件类型,比如gcc  -x   c  hello.xin  -x   none   hi.c

        -c是只激活预处理、编译和汇编,也就是它只把程序做成obj文件,我们可以使用gcc  -c  hello.c会生成.o的obj文件

        -S只激活预处理和编译,能够把文件编译成为汇编代码,比如我们gcc  -S   hello.c会生成.s的汇编代码,我们可以使用文本编辑器查看。

        -E  只激活预处理,这个不生成文件,我们需要把它重定向到一个输出文件里面,比如gcc  -E  hello.c  >  xin.txt或者gcc   -E   hello.c  |more来查看。

        -o指定目标名称,缺省gcc编译出来的文件是a.out,我们可以使用gcc  -o    hello   hello.c的方式。

        -pipe使用管道代替编译中的临时文件,使用非gnu汇编工具的时候可能会有问问题。

       -undef取消对任何非标准宏的定义

       -Idir  在我们使用#include的时候,gcc会先在当前目录查找我们所制定的头文件,如果没有找到,它会到缺省的头目录文件去找,如果使用-I指定了目录,他会先在我们指定的目录查找,然后到常规的目录去找。

      -I-是取消前一个参数的功能,一般在-Idir之后使用。

       -C在预处理的时候,不删除注释信息,一般和-E使用,在分析程序的时候很方便

      -M生成文件关联的信息,包含目标文件所依赖的所有源代码,我们可以用gcc  -M  hello.c来测试

      -MM和-M一样,但是他忽略由#include  <file>造成的依赖关系

      -MD和-M相同,但是将输出导入到.d的文件里面

      -MMD和-MM相同,把输出导入到.d的文件里面

      -library是指定编译时使用的库。

      -Ldir指定编译时,搜索库的路径,其中dir是我们的目录的名称。

     -O0、-O1、-O2、-O3是编译器的优化选项的四个级别,其中-O0表示没有优化,-O1为默认值,而-O3的优化级别最高

     -g只是编译器,在编译的时候,产生调试信息

     -gstabs它以stabs格式产生调试信息,但是不包含gdb调试信息

     -ggdb会产生gdb的调试信息

    -static会禁止使用动态库,因此编译出来的东西一般都很大

    -share会尽量使用动态库,所以生成文件很小,但是需要使用动态库

    -traditional师徒让编译器支持传统C语言特性


郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。