GCC编译

时间:2021-08-11
本文章向大家介绍GCC编译,主要包括GCC编译使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

gcc test.c这样将编译出一个名为a.out的程序
gcc test.c -o test这样将编译出一个名为test的程序,-o参数用来指定生成程序的名

gcc/g++ 命令的常用选项格式(选项 解释)

-o FILE 指定输出文件名,在编译为目标代码时,这一选项不是必须的。如果FILE没有指定,缺省文件名是a.out.

-c 只编译生成目标文件,不链接

-m486 针对 486 进行代码优化。

-O0 不进行优化处理。

-O 或 -O1 优化生成代码。

-O2 进一步优化。

-O3 比 -O2 更进一步优化,包括 inline 函数。

-w 关闭所有警告,建议不要使用此项

-Wall 允许发出gcc能提供的所有有用的警告,也可以用-W(warning)来标记指定的警告

-werror 把所有警告转换为错误,以在警告发生时中止编译过程

-MM 输出一个make兼容的相关列表

-v 显示在编译过程的每一步中用到的命令

-E 只运行 C 预编译器。

-shared 生成共享目标文件。通常用在建立共享库时。

-static 链接静态库,即执行静态链接

-lFOO 链接名为libFOO的函数库

-g 在可执行程序中包含标准调试信息

-ggdb 在可执行程序中包含只有GNU debugger才能使别的达两条是信息

-O 优化编译过的代码

-ON 指定代码优化的级别为N,o<=N<=3

-ansi 支持ANSI/ISO C的标准语法,取消GNU的语法扩展中与该标准有冲突的部分(但这一选项并不能保证生成ANSI兼容的代码) 这一选项将禁止 GNU C 的某些特色, 例如 asm 或 typeof 关键词。

-pedantic 允许发出ANSI/ISO C标准所列出的所有警告

-errors 允许发出ANSI/ISO C标准所列出的所有错误

-traditional 支持Kernighan & Ritchie C语法(如用旧式语法定义函数);如果不知道这个选项的含义,也没有关系
-IDIRECTORY 指定额外的头文件搜索路径DIRECTORY。

-LDIRECTORY 指定额外的函数库搜索路径DIRECTORY。

-DFOO=BAR 在命令行定义预处理宏FOO,其值为BAR

-IDIRNAME 将DIRNAME加入到头文件的搜索目录列表中

-LDIRNAME 将DIRNAME加入到库文件的搜索目录列表中,缺省情况下gcc 只链接共享库

-DMACRO 以字符串“1”定义 MACRO 宏。

-DMACRO=DEFN 以字符串“DEFN”定义 MACRO 宏。

-UMACRO 取消对 MACRO 宏的定义。

原文地址:https://www.cnblogs.com/xianmin/p/15126985.html