啊:
X f(Y y);
A.cpp:
X f(Y y){ ...}
然后在另一个翻译单元:
B.cpp:
#include "A.h"Z g(W w){ ... ... f(...) ... ...}
然后我用gcc 4.6编译两个翻译单元A.o和B.o,然后通过gcc链接它们. (也许两步都是-O3)
gcc会考虑在链接时内联函数来实现性能吗?或者为时已晚?
在代码审查中有人建议我不应该将我的函数声明为内联函数,因为编译器比内联时更了解.除非函数在头文件中定义,否则我总是会留下印象,因为编译器没有内联选项.
(如果C模式,C模式或gnu 0x模式的答案不同,请同时指出这一点)
解决方法 该功能称为 Link Time Optimization(LTO),默认情况下不在GCC 4.6中启用[编辑]启用LTO后,GCC将在A.obj中保存X f(Y y)的“GIMPLE”表示.这种表示比通常的C预处理稍微加工,但不是很多.特别是,它尚未转化为装配.因此,链接器仍然可以内联它.
总结以上是内存溢出为你收集整理的c – 跨翻译单元和gcc 4.6自动内联函数全部内容,希望文章能够帮你解决c – 跨翻译单元和gcc 4.6自动内联函数所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)