《C++ Primer》笔记-inline内联函数

inline 函数避免函数调用的开销

// find longer of two strings
const string &shorterString(const string &s1, const string &s2)
{
         return s1.size() < s2.size() ? s1 : s2;
}

将 shorterString 写成函数有一个潜在的缺点:调用函数比求解等价 表达式要慢得多。在大多数的机器上,调用函数都要做很多工作;调用前要先保 存寄存器,并在返回时恢复;复制实参;程序还必须转向一个新位置执行。

将函数指定为 inline 函数,(通常)就是将它在程序中每个调用点上“内联地”

展开。假设我们将 shorterString 定义为内联函数,则调用: cout << shorterString(s1, s2) << endl;

在编译时将展开为:

         cout << (s1.size() < s2.size() ? s1 : s2)
<< endl;

从而消除了把 shorterString 写成函数的额外执行开销。

// inline version: find longer of two strings
inline const string &
shorterString(const string &s1, const string &s2)
{
return s1.size() < s2.size() ? s1 : s2;

}

一般来说,内联机制适用于优化小的、只有几行的而且经常被调用的函数。 大多数的编译器都不支持递归函数的内联。一个 1200 行的函数也不太可能在调 用点内联展开。

把 inline 函数放入头文件

内联函数应该在头文件中定义,这一点不同于其他函数。

inline 说明对于编译器来说只是一个建议,编译器可以选择忽 略这个。

把 inline 函数的定义放在头文件中,可以确保在调用函数时所使用的定义是相同 的,并且保证在调用点该函数的定义对编译器可见。

在头文件中加入或修改 inline 函数时,使用了该头文件的所 有源文件都必须重新编译。

上一篇:大数据时代,银行BI应用的方案探讨


下一篇:mysql优化 个人笔记(mysql安装 + profile + performance schema) 非礼勿扰 -m01