c – 跨翻译单元和gcc 4.6自动内联函数

c – 跨翻译单元和gcc 4.6自动内联函数,第1张

概述如果我没有声明函数f为内联.如下: 啊: 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会考虑 如果我没有声明函数f为内联.如下:

啊:

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自动内联函数所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1255997.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-07
下一篇 2022-06-07

发表评论

登录后才能评论

评论列表(0条)

保存