我怀疑gcc预处理器不能正确工作,因为编译时间与有没有注释和有没有优化有莫名其妙的关系。
我有一个巨大的Matlab生成的c文件(大约70.000行)。
我注意到,当我用优化级别的-O3编译它时,它需要> 30分钟才能编译。当关闭优化(-O0)时,只需要4分钟。这正是我所期望的,因为在大文件上优化可能很复杂。
但是,如果我在没有注释的情况下在Matlab中生成相同的文件(或者使用编辑器删除它们),它在16分钟内编译完成,在2分钟内没有优化。
因子2从何而来?我希望优化是在预处理之后完成的,并且预处理应该删除任何注释。这将导致独立于O电平的固定时间差。我很困惑。
我尝试显示预处理后的输出(使用gcc选项-E),但没有注释。如果我另外使用了选项-C,就会有注释。
如果我删除空行和连续的空格,它也会影响编译时间。编译时间似乎是线性文件大小,取决于...
发布于 2019-08-16 22:52:59
我找到了原因:
有人(在项目的早期阶段)打开了"-Wa,-amhls“选项,这会导致汇编程序从.S和.C输入文件生成一个> 500.000行的组合.lst文件。
在Windows机器上构建该文件需要超过30分钟。(Linux要快得多!)
这也是为什么构建时间取决于优化和注释打开/关闭的原因。这两者都会影响该.lst文件的长度。
关闭该选项后,我的项目构建时间不到3分钟。
https://stackoverflow.com/questions/57497786
复制相似问题