C++中的内联函数

来源:互联网 发布:文档加密软件功能 编辑:程序博客网 时间:2024/06/15 01:11

一、基本概念

C++中的内联函数由inline关键字修饰,它实现了真正的内嵌,基本形式如下:

inline 函数的返回类型 函数名(参数1, 参数2, …);

示例:

inline int add(int a, int b){    return a + b;}

二、内联函数的小案例

#include<iostream>using namespace std;inline void func(int a){    a = 20;    cout << a << endl;}int main(void){    func(10);    /*    //编译器将内联函数的函数体直接展开    {        a = 20;        cout << a <<endl;    }    */    return 0;}

结果输出: 20

三、 内联函数的特点

1、内联函数必须由inline来修饰并且必须和函数定义结合在一起,否则编译器会直接忽略内联请求
2、C++编译器直接将函数体插入在函数调用的地方
3、内联函数没有普通函数调用时的额外开销(压栈、跳转、返回)
4、内联函数是一种特殊函数,具有普通函数的特征。
5、内联函数由编译器处理,直接将编译后的函数体插入调用的地方
6、C++编译器中内联函数编译限制

  • 不能存在任何形式的循环语句
  • 不能存在过多的条件判断语句
  • 函数体不能过于庞大
  • 不能对函数进行取址操作
  • 函数内联声明必须在调用语句之前

7、编译器对于内联函数的限制并不是绝对的,内联函数相对于普通函数的优势只是省去了函数调用时压栈,跳转和返回的开销。因此,当函数体的执行开销远大于压栈,跳转和返回所用的开销时,那么内联将无意义。

四、内联函数与宏函数

内联函数

优点:内嵌代码,辟免压栈与出栈的开销
缺点:代码替换,易使⽣生成代码体积变⼤大,易产⽣生逻辑错误。

宏函数

优点:⾼高度抽象,避免重复开发
缺点:压栈与出栈,带来开销

五、内联函数的总结

优点:避免调用时的额外开销(入栈与出栈操作)
代价:由于内联函数的函数体在代码段中会出现多个“副本”,因此会增加代码段的空间。

1 0