C++内联函数作用及弊端

 

为什么要使用内联函数?

因为函数调用时候需要创建时间、参数传入传递等操作,造成了时间和空间的额外开销。C++追求效率所以引入了内联的概念。

通过编译器预处理,在调用内联函数的地方将内联函数内的语句Copy到调用函数的地方,从而提高了效率,减少了一些不必要的开销。

内联函数定义?

使用关键字:inline  函数定义形式:inline [返回类型] [函数名]( 参数表 ){[函数体]}

例子:

当调用max函数本身所产生的开销可能比函数内语句执行开销大,所以我们采用内联函数,减少调用开销。

#include<iostream>
using namespace std;
inline int Max(int a,int b){   //定义内联函数
    if(a>b) return a;
    else return b;
}
int main(){
    int a = 3;
    int b = 5;
    cout << "Max:" << Max(a,b) << endl;  //内联函数的定义
}

当调用了这个Max函数时,经过编译器预处理后真正执行的程序可能是下面这个样子

#include<iostream>
using namespace std;
int main(){
    int a = 3;
    int b = 5;
    int temp;
    if(a>b) temp = a;
    else temp = b;
    cout << "MAX:" << temp << endl;;
}

 内联函数的弊端

使用内联函数后虽然调用函数的开销降低了,但是有利必有弊,内联函数会导致主函数指令增多、函数体积增大等情况。

开发中要根据情况正确使用内联函数 。

原文地址:https://www.cnblogs.com/liqiujiong/p/8748926.html