自动内联翻译单元和gcc 4.6

如果我没有声明函数f为内联。 如下:

啊:

X f(Y y); 

A.cpp:

 X f(Y y) { ... } 

然后在另一个翻译单元:

B.cpp:

 #include "Ah" Z g(W w) { ... ... f(...) ... ... } 

然后我用gcc 4.6编译两个翻译单元Ao和Bo,然后通过gcc链接它们。 (可能两个步骤都是-O3)

gcc是否会考虑在链接时内联函数的function? 或者为时已晚?

在代码审查中有人建议我不应该将我的函数声明为内联函数,因为编译器比内联时更了解。 除非函数在头文件中定义,否则我总是会留下印象,因为编译器没有内联选项。

(如果C模式,C ++模式或gnu ++ 0x模式的答案不同,请同时指出这一点)

该function称为链路时间优化(LTO) ,默认情况下不在GCC 4.6中启用

[编辑]启用LTO后,GCC将在A.obj保存X f(Y y)的“GIMPLE”表示。 这种表示比通常的C ++预处理略有处理,但不是很多。 特别是,它尚未转化为assembly。 因此,链接器仍然可以内联它。

我不认为gcc可以创建make函数拆分为不同的源文件作为内联。 它只适用于在同一源文件中声明它们。

编译器可以选择内联或不内联以提高性能。 但在这种情况下,我认为编译器是无助的。 它无法内联函数f。

注意:即使你使用关键字只是一个建议。 是否内联的最终决定取决于编译器。 所以建议编译器没有任何问题。