首页 文章

使用#pragma GCC优化进行C代码优化

提问于
浏览
3

我正在尝试使用GCC编译指示优化来设置我的C代码中的全局优化 . GCC版本在Ubuntu上是4.4.3 . 基本思想是使用功能特定的优化级别 .

#pragma GCC optimize ("O3")

我的C代码中的main函数之前出现了编译错误

但是当我构建它时,我得到编译错误如下 -

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 GCC中是否支持 #pragma optimize

如果是,那么我在使用此pragma优化代码时所做的错误是什么 .

用于优化速度代码的任何其他替代GCC指令?

EDIT :我甚至尝试了 #pragma GCC push_options 然后 #pragma GCC optimize ("O3") 并在文件末尾 #pragma GCC pop_options ;同样的错误 .

2 回答

  • 8

    导致分段错误的ICE(内部编译器错误)始终是编译器中的错误,这就是它要求您报告错误的原因 . 您不应该使用任何源代码(有效或无效)使编译器崩溃 . (可能会发生各种各样的事情,通常涉及拒绝编译无效代码,但崩溃不是其中之一 . )

    由于GCC 4.6.1是最新的,为什么不考虑升级到更新版本的GCC(不是4.4.3就是那么久) .

    在提交错误报告之前,您应该尽量减少繁殖 . 第494行以后的所有内容都可能并不重要;幸运的是,你可以将第1行和第493行之间的材料从近500减少到20左右 . 你当然应该尽可能地减少它,同时保留错误 . 在开始砍掉代码之前,请保留崩溃编译器的版本 . 在保留崩溃的同时成功删除代码时,请将每个后续版本检查到VCS中 . (你正在使用VCS,不是一个修辞问题;如果你是开始的好时机 . 在消除标准 Headers 之前,你需要一个避免进行更改的问题 . )尽量摆脱尽可能多的 Headers . 注意预处理源的请求 - 我所说的代码减少减少了预处理源的大小 .

  • 4

    对于最后一个问题:您可以将其放入单独的编译单元并使用命令行开关: -O3

相关问题