IT博客汇
  • 首页
  • 精华
  • 技术
  • 设计
  • 资讯
  • 扯淡
  • 权利声明
  • 登录 注册

    [转]g++/gcc选项

    liuzhoulong发表于 2014-03-25 11:21:31
    love 0

    添加运行时共享库目录

    运行使用共享库的程序需要加载共享库(不同于G++ 编译时指定的链接库),添加共享库的步骤:

    1. 修改文件 /etc/ld.so.conf 添加共享库目录
    2. 运行 ldconfig 同步更新一下

    如:

    1gedit /etc/ld.so.conf
    2 #添加 /root/dreamlove/lib
    3ldconfig

    添加include,lib的搜寻路径

    对所有用户有效修改/etc/profile
    对个人有效则修改~/.bashrc
    #在PATH中找到可执行文件程序的路径。 export PATH =$PATH:$HOME/bin
    #gcc找到头文件的路径 C_INCLUDE_PATH=/usr/include/libxml2:/MyLib export C_INCLUDE_PATH
    #g++找到头文件的路径 CPLUS_INCLUDE_PATH=$CPLUS_INCLUDE_PATH:/usr/include/libxml2:/MyLib export CPLUS_INCLUDE_PATH
    #找到动态链接库的路径 LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/MyLib export LD_LIBRARY_PATH

    #找到静态库的路径 LIBRARY_PATH=$LIBRARY_PATH:/MyLib export LIBRARY_PATH
    使用source,加载这些定义使其立即生效;或者重启

    g++编译时的流程

    • 调用预编器CPP进行预处理,生成.i文件
    • 调用编译器egcs进行汇编,生成.s文件
    • 调用汇编器as生成目标,.o文件
    • 调用连接器ld进行链接,生成可执行文

    g++使用注意项

    用于链接库的 -l 选项必须放在 g++ 选项后面,如:

    1g++ -o ./tmpExec/pthread pthread.cpp -lpthread
    2 #这个是正确的
    3g++ -lpthread -o ./tmpExec/pthread pthead.cpp #出错


    应该注意的选项

    MM选项与M选项

    生成文件的依赖关系,比如:g++ -MM testMM.cpp;将依赖关系输出到屏幕上,此时应该对其进行重定向;-MM是不会进行语法检查的。只是对源文件的include关系进行分析得到依赖关系;如

    1#include
    2#include "geteth0Ip.h"
    3
    4int mian(){
    5 return;
    6}
    7//这个漏洞百出的源文件仍然可以使用-MM获得它的依赖关系
    与 makefile 的使用:
    1$(dfiles):%.d:%.cpp
    2 @g++ -MM $< | sed '$ a\\tg++ -c -o $(ObjsDir)/$(patsubst %.d,%.o,$@) $<' >$(DsDir)/$@
    3 # 使得每一个 .d 文件都包含着一个完整的规则



    常用选项

    g++ -fsigned-char -o test.exe hello.cpp
    选项参数描述例子
    -x'c|c++|..|'不再根据源文件的后缀名来判断编写源文件的语言,即指定源文件的语言g++ -x 'c++' test.txt
    -E
    只执行编译的第一个流程:预处理,不会生成文件,可以重定向到文件g++ -E test.cpp
    -S
    执行编译的前两个流程生成汇编代码g++ -S test.cpp
    -c
    执行前三个流程生成目标文件g++ -c test.cpp
    -o目标文件名重命名目标文件名g++ -S -o test.asm test.cpp
    -pipe
    使用管道来存储文件,下一个流程从/tmp/文件夹中读取上一个流程的结果,使用pipe后,上一个流程将结果保存在内存中,下一个流程直接从内存中读取上一个流程的结果g++ -pipe -o test.exe test.cpp
    -ansi
    关闭gun的特性,使代码全面符合ansi要求,从而具有高移植性g++ -ansi -o test.ext test.cpp
    -fno-asm
    -ansi的一部分:将asm,inline,typeof视为普通标识符g++ -fno-asm -o test.exe test.cpp
    -fno-strict-prototype
    不再支持
    -fthis-is-variable
    不再支持
    -fcond-mismatch
    允许条件表达式的第2,3个参数的类型不一致,现已默认开启默认开启
    -funsigned-char
    -fno-signed-char
    -fsigned-char
    -fno-unsigned-char

    对char类型进行设置,决定将char类型设置成unsigned char(前两个参数)或者signed char(后两个参数)
    -imacros包含宏的文件相当于include,可以直接使用参数文件里的宏g++ -imacros hello.mac hello.cpp
    -Dmacro
    -Dmacro=defn
    macro为参数相当于#define macrog++ -DUNICODE -o test.exe hello.cpp
    -Umacromacro为参数相当于#undef macro,不能取消在文本文件中定义的宏!g++ -UUNICODE -o test.exe hello.cpp
    -undef
    取消对任何非标准宏的定义g++ -undef -o test.exe hello.cpp
    -Idirdir就是参数一般查找头文件顺序:-I指定的目录->当前目录->环境变量定义的目录g++ -I'C:/Users/Dream/Desktop/' -o test.exe hello.cpp
    -nostdinc
    使编译器不在系统缺省的头文件目录里面找头文件g++ -nostdinc -o test.exe -c hello.cpp
    -C
    在预处理的时候,不删除注释信息,一般和-E使用,有时候分析程序,用这个很方便的g++ -E -C -o test.h hello.cpp
    -M
    生成文件关联的信息。包含目标文件所依赖的所有源文件,这个在制作makefile应该会很有用g++ -M -o test1.h hello.cpp
    -MM
    同-M,不过忽略#include>造成的依赖关系g++ -MM -o test.h hello.cpp
    -Waoptions传递参数给as(汇编器)
    -Wloptions传递参数为ld(连接器)
    -llibslib就是参数指定编译的时候所使用的库,liblibs.so(如果static选项设置的话就是liblibs.a)g++ -lprint hello.cpp(链接 libprint.so)
    -Ldirdir就是参数指定查找链接库时的目录g++ -L'C:/Users/Dream/Desktop/' -lprint hello.cpp
    -Onn为参数,表示优化等级取:0,1,2,3进行相应程度的优化g++ -O3 -o test3.asm -S hello.cpp
    -g
    -ggdb
    -gstabs
    -gstabe+

    生成调试信息,可以被gdb使用
    尽可能地生成gdb格式的调试信息
    生成stabs格式的调试信息
    同时shengc stabs,gdb格式的信息
    g++ -g hello.cpp


沪ICP备19023445号-2号
友情链接