Chinaunix首页 | 论坛 | 博客
  • 博客访问: 5872708
  • 博文数量: 671
  • 博客积分: 10010
  • 博客等级: 上将
  • 技术积分: 7310
  • 用 户 组: 普通用户
  • 注册时间: 2006-07-14 09:56
文章分类

全部博文(671)

文章存档

2011年(1)

2010年(2)

2009年(24)

2008年(271)

2007年(319)

2006年(54)

我的朋友

分类: C/C++

2009-03-05 15:49:15

gcc/g++在执行编译工作的时候,总共需要4步
1.预处理,生成.i的文件[预处理器cpp]
2.将预处理后的文件不转换成汇编语言,生成文件.s[编译器egcs]
3.有汇编变为目标代码(机器代码)生成.o的文件[汇编器as]
4.连接目标代码,生成可执行程序[链接器ld]
参数详解
-c 只激活预处理,编译,和汇编,也就是他只把程序做成obj文件   
eg: gcc -c hello.c 生成.o的obj文件
-o 制定目标名称,缺省的时候,gcc 编译出来的文件是a.out
eg:gcc -o hello.exe hello.c 
gcc -o hello.asm -S hello.c
–D 允许从编译程序命令行定义宏符号
       一共有两种情况:一种是用-DMACRO,相当于在程序中使用#define MACRO,另一种是用-DMACRO=A,相当于程序中的#define MACRO A.
eg:如对下面这段代码:
   #ifdefine DEBUG
               printf("debug message\n");
   #endif
   编译时可加上-DDEBUG参数,执行程序则打印出编译信息
-Umacro   相当于C语言中的#undef macro
-undef   取消对任何非标准宏的定义
-g
指明编译程序在编译的输出中应产生调试信息.这个调试信息使源代码和变量名引用在调试程序中或者当程序异常退出后在分析core文件时可被使用.
-gstabs   此选项以stabs格式声称调试信息,但是不包括gdb调试信息.   
-gstabs+  此选项以stabs格式声称调试信息,并且包含仅供gdb使用的额外调试信息. -ggdb    此选项将尽可能的生成gdb的可以使用的调试信息.
-Wall   以最高级别使用GNU编译程序,专门用于显示警告用!!
   eg:gcc -Wall hello.c
-I dir   
在你是用#include"file"的时候,gcc/g++会先在当前目录查找你所制定的头文件,如 果没有找到,他回到缺省的头文件目录找,如果使用-I制定了目录,他回先在你所制定的目录查找,然后再按常规的顺序去找. 对于#include,gcc/g++会到-I制定的目录查找,查找不到,然后将到系统的缺 省的头文件目录查找
eg:gcc -c -I/usr/local/include -I/opt/include hello.c 此时目录搜索会按给出的次序进行.
-I-  就是取消前一个参数的功能,所以一般在-Idir之后使用
-idirafter dir   在-I的目录里面查找失败,到这个目录里面查找
-iprefix prefix -iwithprefix dir
一般一起使用,当-I的目录查找失败,会到prefix+dir下查找
-nostdinc
使编译器不再系统缺省的头文件目录里面找头文件,一般和-I联合使用,明确限定头文件的位置
-nostdin C++
规定不在g++指定的标准路经中搜索,但仍在其他路径中搜索,.此选项在创libg++库使用
-S 只激活预处理和编译,就是指把文件编译成为汇编代码。   
eg:gcc -S hello.c 生成.s的汇编代码,你可以用文本编辑器查看
-E
只激活预处理,这个不生成文件,你需要把它重定向到一个输出文件里面. 这个选项是相对标准的,它允许修改命令行以使编译程序把预先处理的C文件发到标准输出,而不实际编译代码.在查看C预处理伪指令和C宏时,这是很有用的.可能的编译输出可重新定向到一个文件,然后用编辑程序来分析:
    eg:   gcc -c -E hello.c >cpp.out
此命令使include文件和程序被预先处理并重定向到文件cpp.out.以后可以用编辑程序或者分页命令分析这个文件,并确定最终的C语言代码看起来如何.
gcc -E hello.c > pianoapan.txt   
gcc -E hello.c | more   可以用来去掉文件中的注释
-pipe 使用管道代替编译中临时文件,在使用非GNU汇编工具的时候,可能有些问题
eg:gcc -pipe -o hello.exe hello.c
-C
在预处理的时候,不删除注释信息,一般和-E使用,有时候分析程序,用这个很方便的
-M
生成文件关联的信息。包含目标文件所依赖的所有源代码你可以用gcc -M hello.c 来测试一下,很简单。
-MM 和上面的那个一样,但是它将忽略由#include造成的依赖关系。   
-MD   和-M相同,但是输出将导入到.d的文件里面   
-MMD 和-MM相同,但是输出将导入到.d的文件里面   
-Wa,option  
此选项传递option给汇编程序;如果option中间有逗号,就将option分成多个选项,然 后传递给会汇编程序   
-Wl.option
此选项传递option给连接程序;如果option中间有逗号,就将option分成多个选项,然 后传递给会连接程序.   
-Ldir指定连接库的搜索目录,制定编译的时候,搜索库的路径。比如你自己的库,可以用它制定目录,不然编译器将只在标准库的目录找。这个dir就是目录的名称。
-llibrary指定连接库的名字
   eg:gcc main.o -L/usr/lib -lqt -o hello
    上面的命令把目标文件main.o与库qt相连接,连接时会到/usr/lib查找这个库文件.也就是说-L与-l一般要成对出现.
-static
此选项将禁止使用动态库,所以,编译出来的东西,一般都很大,也不需要什么 动态连接库就可以运行.
-share   此选项将尽量使用动态库,所以生成文件比较小,但是需要系统由动态库.
-traditional   试图让编译器支持传统的C语言特性
-ansi 关闭gnu c中与ansi c不兼容的特性,激活ansi c的专有特性(包括禁止一些
asm inl ine typeof关键字,以及UNIX,vax等预处理宏,
-fno-asm  此选项实现ansi选项的功能的一部分,它禁止将asm,inline和typeof用作
关键字。
-fno-strict-prototype
只对g++起作用,使用这个选项,g++将对不带参数的函数,都认为是没有显式的对参数的个数和类型说明,而不是没有参数. 而gcc无论是否使用这个参数,都将对没有带参数的函数,认为城没有显式说明的类型
-fthis-is-varialble  就是向传统c++看齐,可以使用this当一般变量使用.
-fcond-mismatch
允许条件表达式的第二和第三参数类型不匹配,表达式的值将为void类型
-funsigned-char
-fno-signed-char
-fsigned-char
-fno-unsigned-char
这四个参数是对char类型进行设置,决定将char类型设置成unsigned char(前两个参数)或者signed char(后两个参数)
-include file
包含某个代码,简单来说,就是便以某个文件,需要另一个文件的时候,就可以用它设 定,功能就相当于在代码中使用#include
eg: gcc hello.c -include /root/pianopan.h
-imacros file
将file文件的宏,扩展到gcc/g++的输入文件,宏定义本身并不出现在输入文件中
-x language filename   设定文件所使用的语言,使后缀名无效,对以后的多个有效.也就是根据约定C语言的后 缀名称是.c的,而C++的后缀名是.C或者.cpp。这个参数对他后面的文件名都起作用,除非到了下一个参数的使用。 可以使用的参数有下面的这些`c', `objective-c', `c-header', `c++', `cpp-output', `assembler', and `a ssembler-with-cpp'.
eg: gcc -x c hello.pig
-x none filename
关掉上一个选项,也就是让gcc根据文件名后缀,自动识别文件类型
eg: gcc -x c hello.pig -x none hello2.c
阅读(2319) | 评论(0) | 转发(1) |
给主人留下些什么吧!~~