我正在尝试使用GCC编译指示优化来在我的C代码中设置全局优化。 GCC版本在Ubuntu上是4.4.3。基本思想是使用功能特定的优化级别。
#pragma GCC optimize ("O3")
我收到编译错误 就在我的C代码中的主函数之前
但是当我构建它时,我得到编译错误,如下所示 -
passrecovery.c: In function âmainâ:
passrecovery.c:493: internal compiler error: Segmentation fault
Please submit a full bug report,
with preprocessed source if appropriate.
See <file:///usr/share/doc/gcc-4.4/README.Bugs> for instructions.
make: *** [all] Error 1
我检查了错误中提到的README.Bugs文件,但没有找到关于此的线索。
4.4.3海湾合作委员会是否支持#pragma optimize
?
如果是,那么我在使用此pragma优化代码时所做的错误是什么。
用于优化速度代码的任何其他替代GCC指令?
编辑:我甚至尝试了#pragma GCC push_options
然后#pragma GCC optimize ("O3")
和文件#pragma GCC pop_options
的结尾;同样的错误。
答案 0 :(得分:8)
导致分段错误的ICE(内部编译器错误)始终是编译器中的错误,这就是它要求您报告错误的原因。您不应该使用任何源代码(有效或无效)使编译器崩溃。 (可能会发生各种各样的事情,最常见的是拒绝编译无效代码,但崩溃不是其中之一。)
由于GCC 4.6.1是最新的,为什么不考虑升级到更新版本的GCC(不是4.4.3就是那么久)。
在提交错误报告之前,您应该尽量减少繁殖。第494行以后的所有内容都可能并不重要;幸运的是,你可以将第1行和第493行之间的材料从近500减少到20左右。你当然应该尽可能地减少它,同时保留错误。在开始砍掉代码之前,请保留崩溃编译器的版本。在保留崩溃的同时成功删除代码时,请将每个后续版本检查到VCS中。 (你 使用VCS,不是吗?这是一个修辞问题;如果你不是,现在是开始的好时机。你需要一个避免做出无法修改的改变。)在删除标准标题之前,尝试消除非标准标题(您已编写的标题)。尽量摆脱尽可能多的标题。请注意预处理源的请求 - 我所说的代码缩减减少了预处理源的大小。
答案 1 :(得分:4)
对于最后一个问题:您可以将它放入单独的编译单元并使用命令行开关:-O3