GCC编译器选项及优化提示

合集下载

GCC编译器选项及优化提示

GCC编译器选项及优化提示

[原创]GCC编译器‎选项及优化提‎示很多弟兄可能‎都很关心如何‎优化编译自己‎的程序,虽然本人不赞‎成"骨灰"玩法,却也不得不承‎认这是掌握g‎c c的绝佳途‎径;因此献上此帖‎,以供各位玩家‎参考,绝对原创噢============================大多数程序和‎库在编译时默‎认的优化级别‎是"2"(使用gcc选‎项:"-O2")并且在I nt‎e l/AMD平台上‎默认按照i3‎86处理器来‎编译。

如果你只想让‎编译出来的程‎序运行在特定‎的平台上,就需要执行更‎高级的编译器‎优化选项,以产生只能运‎行于特定平台‎的代码。

一种方法是修‎改每个源码包‎中的M ake‎f ile文件‎,在其中寻找C‎F LAGS和‎C XXFLA‎G S变量(C和C++编译器的编译‎选项)并修改它的值‎。

一些源码包比‎如binut‎i ls, gcc, glibc等‎等,在每个子文件‎夹中都有M a‎k efile‎文件,这样修改起来‎就太累了!另一种简易做‎法是设置C F‎L AGS和C‎X XFLA G‎S环境变量。

大多数c on‎f igure‎脚本会使用这‎两个环境变量‎代替M ake‎f ile文件‎中的值。

但是少数c o‎n figur‎e脚本并不这‎样做,他们必须需要‎手动编辑才行‎。

为了设置C F‎L AGS和C‎X XFLA G‎S环境变量,你可以在ba‎s h中执行如‎下命令(也可以写进.bas hrc‎以成为默认值‎):export‎C FLA GS‎="-O3 -marc h=<c pu类型>" && C XXFLA‎G S=$CFLAGS‎这是一个确保‎能够在几乎所‎有平台上都能‎正常工作的最‎小设置。

"-marc h"选项表示为特‎定的c pu类‎型编译二进制‎代码(不能在更低级‎别的c pu上‎运行),I ntel通‎常是:pentiu‎m2, pentiu‎m3, pentiu‎m3m, pentiu‎m4, pentiu‎m4m, pentiu‎m-m, pres c o‎t t, noc ona‎说明:pentiu‎m3m/pentiu‎m4m是笔记‎本用的移动P‎3/P4;pentiu‎m-m是迅驰I/II代笔记本‎的c pu;pres c o‎t t是带SS‎E3的P4(以滚烫到可以‎煎鸡蛋而闻名‎);noc ona‎则是最新的带‎有E M T64‎(64位)的P4(同样可以煎鸡‎蛋)AMD通常是‎:k6, k6-2, k6-3, athlon‎, athlon‎-tbird, athlon‎-xp, athlon‎-mp, optero‎n, athlon‎64, athlon‎-fx用AMD的一‎般都是DI Y‎e r,就不必解释了‎吧。

C语言中的编译器优化标志有哪些?

C语言中的编译器优化标志有哪些?

C语言中的编译器优化标志有哪些?在 C 语言编程中,编译器优化标志是提升程序性能的重要工具。

它们能够让编译器以不同的方式处理代码,从而生成更高效的机器码。

接下来,让我们详细了解一下常见的编译器优化标志。

首先,“O1”是一个较为基础的优化级别。

它会执行一些常见的优化操作,比如常量折叠、简单的指令替换和消除一些不必要的代码。

常量折叠指的是在编译时直接计算那些在运行时不会改变的值,例如“5 +3”会在编译时直接计算为 8 。

简单的指令替换可能会将一些效率较低的指令替换为更高效的等价指令。

“O2”优化级别比“O1”更进一步。

除了包含“O1”的优化之外,还会进行更多的循环优化和函数内联。

循环优化可以减少循环中的开销,提高循环的执行效率。

函数内联则是将一些小的、被频繁调用的函数直接嵌入到调用它的地方,避免了函数调用的开销。

“O3”是更高级别的优化。

它在“O2”的基础上增加了一些更激进的优化策略,例如强度削减和自动向量化。

强度削减是指将一些复杂的运算转换为更简单但等价的运算,以提高执行速度。

自动向量化则是将一些可以并行执行的操作转换为向量指令,利用现代处理器的向量处理能力来提高性能。

除了上述常见的整体优化级别,还有一些特定的优化标志。

比如“fomitframepointer”,它会省略帧指针以节省空间和提高性能,但这可能会使调试变得更困难。

“funrollloops”标志会将小的循环展开,以减少循环控制的开销,但可能会导致代码体积增大。

“ftreevectorize”明确指示编译器尝试进行向量化优化。

“foptimizesiblingcalls”用于优化兄弟函数调用,以减少函数调用的开销。

“fmergeallconstants”会合并相同的常量,节省存储空间。

另外,不同的编译器可能还提供了一些特定的优化标志。

例如,GCC 编译器中的“fnostrictaliasing”用于控制严格别名规则,这在某些情况下可能会影响优化。

GCC编译选项参数

GCC编译选项参数

GCC编译选项参数1. -o,指定输出文件的名称。

例如,gcc -o output main.c将生成一个名为output的可执行文件。

2.-c,只编译源文件但不链接生成可执行文件。

这个选项可以用于分离编译,将源代码和编译后的目标文件分开存放。

3.-g,生成包含调试信息的可执行文件。

这个选项可用于在程序出错时进行调试。

4. -Wall,显示所有警告信息。

这个选项用于尽可能多地检测潜在的错误。

5. -Werror,将警告视为错误。

这个选项会将所有警告信息转化为编译错误,编译过程中如果遇到任何警告就会停止编译。

6. -std,指定所使用的C或C++的标准版本。

例如,-std=c99指定使用C99标准。

7.-I,指定额外的头文件路径。

可以通过多次使用该选项来指定多个路径。

8.-L,指定额外的库文件路径。

可以通过多次使用该选项来指定多个路径。

9. -l,指定要链接的库文件。

例如,-lmath将链接数学库。

10.-O,指定优化级别。

有多个优化级别可选,从-O0(不进行任何优化)到-O3(进行最高级别的优化)。

11.-D,定义预处理宏。

可以使用-D定义宏并为其指定值。

例如,-DDEBUG定义一个名为DEBUG的宏。

12.-U,取消预定义宏的定义。

可以使用-U取消已定义的宏。

13.-E,只进行预处理,生成预处理后的源代码。

可以通过这个选项将预处理后的代码输出到标准输出或另一个文件中。

14.-S,只进行编译,生成汇编代码。

可以通过这个选项将汇编代码输出到标准输出或另一个文件中。

15. -shared,生成共享库文件。

这个选项可以用于生成可供其他程序调用的动态链接库。

16.-fPIC,生成位置无关的代码。

这个选项可以用于在共享库中使用。

17. -pthread,为多线程程序链接额外的线程库。

18. -march,指定目标处理器的架构。

例如,-march=armv7指定目标处理器是ARMv7架构。

19. -mfpu,指定使用的浮点单元类型。

GCC常用编译命令选项

GCC常用编译命令选项

GCC常⽤编译命令选项假设源程序⽂件名为main.c1. ⽆选项编译链接⽤法: gcc main.c作⽤: main.c预处理、汇编、编译并链接形成可执⾏⽂件。

这⾥未指定输出⽂件,默认输出为a.out。

2. 选项 –o⽤法:gcc main.c -o main.out作⽤:将main.c预处理、汇编、编译并链接形成可执⾏⽂件main.out。

-o选项⽤来指定输出⽂件的⽂件名。

3. 选项 –E⽤法:gcc -E main.c -o main.i作⽤:将 main.c预处理输出 main.i⽂件。

4. 选项 –S⽤法:gcc -S main.i作⽤:将预处理输出⽂件main.i汇编成main.s⽂件。

5. 选项 –c⽤法:gcc -c main.s作⽤:将汇编输出⽂件main.s编译输出main.o⽂件。

6. ⽆选项链接⽤法:gcc main.o -o main.out作⽤:将编译输出⽂件main.o链接成最终可执⾏⽂件main.out。

7. 选项-O⽤法:gcc -O1 main.c -o main.out作⽤:使⽤编译优化级别1编译程序。

级别为1~3,级别越⼤优化效果越好,但编译时间越长。

8.运⾏可执⾏⽂件⽤法:>>./main.out输出结果9.查看动态可执⾏⽂件动态库加载情况⽤法:>>ldd main.exe静态库后缀名⼀般为“.a”动态库后缀名⼀般为“.so”10.反汇编⽤法:objdump -d main.out⼆. 多源⽂件的编译⽅法假设有两个源⽂件为main.c和test.c1、多个⽂件⼀起编译⽤法:gcc main.c test.c -o main.out作⽤:将main.c和test.c分别编译后链接成main.out可执⾏⽂件。

2、分别编译各个源⽂件,之后对编译后输出的⽬标⽂件链接。

⽤法:gcc -c main.c //将main.c编译成main.ogcc -c test.c //将test.c编译成test.ogcc -o main.o test.o -o main//将main.o和test.o链接成main3、如果要编译的⽂件都在同⼀个⽬录下,可以⽤通配符gcc *.c -o 来进⾏编译。

GCC(警告.优化以及调试选项)

GCC(警告.优化以及调试选项)

GCC(警告.优化以及调试选项)[介绍]gcc and g 分别是gnu的c & c 编译器gcc/g 在执行编译工作的时候,总共需要4步1.预处理,生成.i的文件预处理器cpp2.将预处理后的文件不转换成汇编语言,生成文件.s编译器egcs3.有汇编变为目标代码(机器代码)生成.o的文件汇编器as4.连接目标代码,生成可执行程序连接器ld1.总体选项-E只激活预处理,这个不生成文件,你需要把它重定向到一个输出文件里面.例子用法:gcc -E hello.c > pianoapan.txtgcc -E hello.c | more慢慢看吧,一个hello word 也要与处理成800行的代码-S只激活预处理和编译,就是指把文件编译成为汇编代码。

例子用法gcc -S hello.c他将生成.s的汇编代码,你可以用文本编辑器察看-c只激活预处理,编译,和汇编,也就是他只把程序做成obj文件例子用法:gcc -c hello.c他将生成.o的obj文件2.目录选项-Idir在你是用#include'file'的时候,gcc/g 会先在当前目录查找你所制定的头文件,如果没有找到,他回到缺省的头文件目录找,如果使用-I制定了目录,他回先在你所制定的目录查找,然后再按常规的顺序去找.对于#include,gcc/g 会到-I制定的目录查找,查找不到,然后将到系统的缺省的头文件目录查找-include file-i相当于“#include”包含某个代码,简单来说,就是便以某个文件,需要另一个文件的时候,就可以用它设定,功能就相当于在代码中使用#include例子用法:gcc hello.c -include /root/pianopan.h-I-就是取消前一个参数的功能,所以一般在-Idir之后使用-idirafter dir在-I的目录里面查找失败,讲到这个目录里面查找.-iprefix prefix-iwithprefix dir一般一起使用,当-I的目录查找失败,会到prefix dir下查找-Ldir制定编译的时候,搜索库的路径。

GCC编译优化选项

GCC编译优化选项

GCC编译优化选项-march第⼀个重要的选项是-march。

这个选项告诉编译器该为你的处理器(或arch)⽣成何种代码,它告诉编译器只为特定类型的CPU⽣成代码。

不同的CPU具有不同的能⼒,⽀持不同的指令集,以及不同的执⾏代码⽅式。

-march标记指⽰编译器根据你CPU的能⼒、特征、指令集、怪癖等⽣成特定的代码。

即使/etc/make.conf中的CHOST变量指定了所使⽤的通⽤构架,-march还是可以⽤来为特定的处理器优化程序。

x86和x86-64(也包括其他的)的CPU尤其应该利⽤-march标记。

-O接下来是-O变量。

这个选项控制所有的优化等级。

使⽤优化选项会使编译过程耗费更多的时间,并且占⽤更多的内存,尤其是在提⾼优化等级的时候。

-O设置⼀共有五种:-O0、-O1、-O2、-O3和-Os。

你只能在/etc/make.conf⾥⾯设置其中的⼀种。

除了-O0以外,每⼀个-O设置都会多启⽤⼏个选项,请查阅gcc⼿册的章节,以便了解每个-O等级启⽤了哪些选项及它们有何作⽤。

让我们来逐⼀考察各个优化等级:-O0:这个等级(字母“O”后⾯跟个零)关闭所有优化选项,也是CFLAGS或CXXFLAGS中没有设置-O等级时的默认等级。

这样就不会优化代码,这通常不是我们想要的。

-O1:这是最基本的优化等级。

编译器会在不花费太多编译时间的同时试图⽣成更快更⼩的代码。

这些优化是⾮常基础的,但⼀般这些任务肯定能顺利完成。

-O2:-O1的进阶。

这是推荐的优化等级,除⾮你有特殊的需求。

-O2会⽐-O1启⽤多⼀些标记。

设置了-O2后,编译器会试图提⾼代码性能⽽不会增⼤体积和⼤量占⽤的编译时间。

-O3:这是最⾼最危险的优化等级。

⽤这个选项会延长编译代码的时间,并且在使⽤gcc4.x的系统⾥不应全局启⽤。

⾃从3.x版本以来gcc的⾏为已经有了极⼤地改变。

在3.x,-O3⽣成的代码也只是⽐-O2快⼀点点⽽已,⽽gcc4.x中还未必更快。

最新GCC编译器选项及优化提示

最新GCC编译器选项及优化提示

G C C编译器选项及优化提示GCC编译器选项及优化提示GCC编译器选项及优化提示2010-08-01 19:41很多弟兄可能都很关心如何优化编译自己的程序,虽然本人不赞成"骨灰"玩法,却也不得不承认这是掌握gcc的绝佳途径;因此献上此帖,以供各位玩家参考,绝对原创噢=大多数程序和库在编译时默认的优化级别是"2"(使用gcc选项:"-O2")并且在Intel/AMD平台上默认按照i386处理器来编译。

如果你只想让编译出来的程序运行在特定的平台上,就需要执行更高级的编译器优化选项,以产生只能运行于特定平台的代码。

一种方法是修改每个源码包中的Makefile文件,在其中寻找CFLAGS和CXXFLAGS变量(C和C++编译器的编译选项)并修改它的值。

一些源码包比如binutils,gcc,glibc等等,在每个子文件夹中都有Makefile文件,这样修改起来就太累了!另一种简易做法是设置CFLAGS和CXXFLAGS环境变量。

大多数configure 脚本会使用这两个环境变量代替Makefile文件中的值。

但是少数configure脚本并不这样做,他们必须需要手动编辑才行。

为了设置CFLAGS和CXXFLAGS环境变量,你可以在bash中执行如下命令(也可以写进.bashrc以成为默认值):export CFLAGS="-O3-march="&&CXXFLAGS=$CFLAGS这是一个确保能够在几乎所有平台上都能正常工作的最小设置。

"-march"选项表示为特定的cpu类型编译二进制代码(不能在更低级别的cpu上运行),Intel通常是:pentium2,pentium3,pentium3m,pentium4,pentium4m,pentium-m,prescott,nocona说明:pentium3m/pentium4m是笔记本用的移动P3/P4;pentium-m是迅驰I/II代笔记本的cpu;prescott是带SSE3的P4(以滚烫到可以煎鸡蛋而闻名);nocona则是最新的带有EMT64(64位)的P4(同样可以煎鸡蛋)AMD通常是:k6,k6-2,k6-3,athlon,athlon-tbird,athlon-xp,athlon-mp,opteron,athlon64,athlon-fx用AMD的一般都是DIYer,就不必解释了吧。

gcc编译参数

gcc编译参数

gcc编译参数在GCC中,编译参数用于指定编译器的行为和选项。

这些参数可以对代码进行优化、生成调试信息、链接不同的库等等。

以下是一些常用的GCC编译参数:1.优化参数:--O0:不进行优化--O1:进行基本优化--O2:进行更多优化--O3:进行最大优化--Os:进行优化以缩小代码尺寸2.调试参数:--g:生成调试信息- -ggdb:生成GDB可用的调试信息- -gdwarf:生成DWARF调试信息3.警告参数:- -Wall:开启所有警告- -Werror:将所有警告视为错误- -Wextra:开启额外的警告- -Wno-unused-parameter:忽略未使用的函数参数的警告4.标准库参数:- -std=c89:使用C89标准- -std=c99:使用C99标准- -std=c11:使用C11标准- -std=c++98:使用C++98标准- -std=c++11:使用C++11标准- -std=c++14:使用C++14标准- -std=c++17:使用C++17标准5.预处理参数:- -D<symbol>=<value>:定义宏- -U<symbol>:取消宏定义- -I<dir>:指定头文件路径6.链接参数:- -L<dir>:指定库文件路径- -l<library>:链接库文件- -shared:生成共享库- -static:生成静态库7.其他参数:--c:只编译,不链接- -o <output>:指定输出文件名- -Wl,<option>:传递选项给链接器- -Wp,<option>:传递选项给预处理器这只是一小部分常用的GCC编译参数,GCC还提供了许多其他参数用于更精细地控制编译过程。

可以通过运行`gcc --help`命令查看GCC支持的所有编译参数。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

GCC编译器选项及优化提示GCC编译器选项及优化提示2010-08-01 19:41很多弟兄可能都很关心如何优化编译自己的程序,虽然本人不赞成"骨灰"玩法,却也不得不承认这是掌握gcc的绝佳途径;因此献上此帖,以供各位玩家参考,绝对原创噢=大多数程序和库在编译时默认的优化级别是"2"(使用gcc选项:"-O2")并且在Intel/AMD平台上默认按照i386处理器来编译。

如果你只想让编译出来的程序运行在特定的平台上,就需要执行更高级的编译器优化选项,以产生只能运行于特定平台的代码。

一种方法是修改每个源码包中的Makefile文件,在其中寻找CFLAGS和CXXFLAGS变量(C和C++编译器的编译选项)并修改它的值。

一些源码包比如binutils,gcc,glibc等等,在每个子文件夹中都有Makefile文件,这样修改起来就太累了!另一种简易做法是设置CFLAGS和CXXFLAGS环境变量。

大多数configure 脚本会使用这两个环境变量代替Makefile文件中的值。

但是少数configure脚本并不这样做,他们必须需要手动编辑才行。

为了设置CFLAGS和CXXFLAGS环境变量,你可以在bash中执行如下命令(也可以写进.bashrc以成为默认值):export CFLAGS="-O3-march="&&CXXFLAGS=$CFLAGS这是一个确保能够在几乎所有平台上都能正常工作的最小设置。

"-march"选项表示为特定的cpu类型编译二进制代码(不能在更低级别的cpu上运行),Intel通常是:pentium2,pentium3,pentium3m,pentium4,pentium4m,pentium-m,prescott,nocona说明:pentium3m/pentium4m是笔记本用的移动P3/P4;pentium-m是迅驰I/II代笔记本的cpu;prescott是带SSE3的P4(以滚烫到可以煎鸡蛋而闻名);nocona则是最新的带有EMT64(64位)的P4(同样可以煎鸡蛋)AMD通常是:k6,k6-2,k6-3,athlon,athlon-tbird,athlon-xp,athlon-mp,opteron,athlon64,athlon-fx用AMD的一般都是DIYer,就不必解释了吧。

如果编译时没有抱怨"segmentation fault,core dumped",那么你设定的"-O"优化参数一般就没什么问题。

否则请降低优化级别("-O3"-"-O2"-"-O1"-取消)。

个人意见:服务器使用"-O2"就可以了,它是最安全的优化参数(集合);桌面可以使用"-O3";不鼓励使用过多的自定义优化选项,其实他们之间没什么明显的速度差异(有时"-O3"反而更慢)。

编译器对硬件非常敏感,特别是在使用较高的优化级别的时候,一丁点的内存错误都可能导致致命的失败。

所以在编译时请千万不要超频你的电脑(我编译关键程序时总是先降频然的)。

注意:选项的顺序很重要,如果有两个选项互相冲突,则以后一个为准。

比如"-O3"将打开-finline-functions选项,但是可以用"-O3-fno-inline-functions"既使用-O3的功能又关闭函数内嵌功能。

更多的优化选项请参见:所有GCC选项完整列表参见:有两个页面值的参考:(对于gentoo-1.4)比较安全的优化选项(对于gentoo-1.4)进阶优化选项*哦,忘了说一声,"-O2"已经启用绝大多数安全的优化选项了,所以其实你不必对那一堆选项发愁。

先说说"-O3"在"-O2"基础上增加的几项,你可以按需添加(还算比较安全):[gcc-3.4.4]-finline-functions允许编译器选择某些简单的函数在其被调用处展开-fweb为每个web结构体分配一个伪寄存器-frename-registers试图驱除代码中的假依赖关系,这个选项对具有大量寄存器的机器很有效。

[gcc-4.0.2]-finline-functions说明如上-funswitch-loops将循环体中不改变值的变量移动到循环体之外-fgcse-after-reload*不太明白它的含义*[哪位大峡知道给小弟讲解一下,先行谢过说完"-O3"再说说在嵌入式系统上常用的"-Os"选项,这个选项其实也很重要,它的含义是对生成的二进制代码进行尺寸上的优化,它打开了所有"-O2"打开的选项,因此通常认为的"-Os"生成的二进制代码执行效率低的潜在意识是错误的!当然该选项与"-O2"的不同之处在于它在"-O2"的基础上禁止了所有为了对齐而插入的空间,也就是将所有"-falign-*"系列的选项禁用了。

这种禁用究竟是否一定降低了代码的执行效率,依据程序的不同而不同,据说某些情况下"-Os"的效率比"-O3"还要高14%!请兄弟们在实践中自己摸索吧.---下面选择我认为比较重要的几项简单介绍一下[gcc-3.4.4],GCC选项完整列表太长了!精力有限。

[注意]这里列出的都是非默认的选项,你只需要添加你所需要的选项即可-w禁止输出警告消息-Werror将所有警告转换为错误-Wall显示所有的警告消息-v显示编译程序的当前版本号-V指定gcc将要运行的版本。

只有在安装了多个版本gcc的机器上才有效。

-ansi按照ANSI标准编译程序,但并不限制与标准并不冲突的GNU扩展(一般不用该选项)-pedantic如果要限制代码必须严格符合ISO标准,就在"-ansi"的基础上同时启用这个选项(很少使用)-std=指定C语言的标准(c89,c99,gnu89),该选项禁止了GNU C的扩展关键字asm,typeof,inline(一般不用该选项)-static连接器将忽略动态连接库,同时通过将静态目标文件直接包含到结果目标文件完成对所有引用的解析。

-shared连接器将生成共享目标代码,该共享库可在运行时动态连接到程序形成完整的可执行体。

如果使用gcc命令创建共享库作为其输出,该选项可以防止连接器将缺失main()方法视为错误。

为了可以正确的工作,应该一致的使用选项"-fpic"以及目标平台选项编译构成同一个库的所有共享目标模块。

-shared-libgcc该选项指定使用共享版本的libgcc,在没有共享版本的libgcc的机器上该选项无效。

-specs=gcc驱动程序读取该文件以确定哪些选项应该传递给那些子进程。

该选项可以通过指定配置文件来覆盖默认配置,指定的文件将在默认配置文件读取后进行处理以修改默认配置。

-pipe使用管道而不是临时文件一个阶段到另一个阶段交换输出的方式,可以加快编译速度。

建议使用。

-o指定输出文件,对各种输出皆有效。

由于只能指定一个文件,所以在产生多个输出文件的情况下不要使用该选项。

--help显示gcc的命令行选项列表;与"-v"一起使用时还将显示gcc调用的各个进程所接受的选项。

--target-help显示目标机器相关的命令行选项列表-b指示需要编译程序的目标机器;默认为编译程序所运行的目标机编译代码。

目标机通过指定包含编译程序的目录来确定,通常为/usr/local/lib/gcc-lib//-B指定库文件的位置,包括编译程序的文件、执行程序和数据文件,如果需要运行子程序(如cpp,as,ld)就会用该前缀来定位。

这个前缀可以是用冒号分割的多个路径,环境变量GCC_EXEC_PREFIX和这个选项有相同的效果。

-I指定搜索系统头文件的目录,可以重复使用多个该选项指定多个目录。

-dumpmachine显示该程序的目标机名字,不做其他任何动作-dumpspecs显示构件编译程序的规范信息,包括用来编译、汇编和连接gcc编译程序自身用到的所有选项,不做其他任何动作。

-dumpversion显示编译程序自身的版本号,不做其他任何动作-falign-functions=N将所有函数的起始地址在N(N=1,2,4,8,16.)的边界上对齐,默认为机器自身的默认值,指定为1表示禁止对齐。

-falign-jumps=N将分支目标在N(N=1,2,4,8,16.)的边界上对齐,默认为机器自身的默认值,指定为1表示禁止对齐。

-fno-align-labels建议使用它,以保证不和-falign-jumps("-O2"默认启用的选项)冲突-fno-align-loops建议使用它,以确保不会在分支目标前插入多余的空指令。

-fbranch-probabilities在使用"-fprofile-arcs"选项编译程序并执行它来创建包含每个代码块执行次数的文件之后,程序可以利用这一选项再次编译,文件中所产生的信息将被用来优化那些经常发生的分支代码。

如果没有这些信息,gcc将猜测那一分支可能经常发生并进行优化。

这类优化信息将会存放在一个以源文件为名字的并以".da"为后缀的文件中。

-fno-guess-branch-probability默认情况下gcc将使用随机模型进行猜测哪个分支更可能被经常执行,并以此来优化代码,该选项关闭它。

-fprofile-arcs在使用这一选项编译程序并运行它以创建包含每个代码块的执行次数的文件后,程序可以再次使用"-fbranch-probabilities"编译,文件中的信息可以用来优化那些经常选取的分支。

如果没有这些信息,gcc 将猜测哪个分支将被经常运行以进行优化。

这类优化信息将会存放在一个以源文件为名字的并以".da"为后缀的文件中。

-fforce-addr必须将地址复制到寄存器中才能对他们进行运算。

由于所需地址通常在前面已经加载到寄存器中了,所以这个选项可以改进代码。

-fforce-mem必须将数值复制到寄存器中才能对他们进行运算。

由于所需数值通常在前面已经加载到寄存器中了,所以这个选项可以改进代码。

相关文档
最新文档