c++中的内联函数

语法:在普通函数声明之前加一个 inline

void max(){;} ----普通函数
inline void max(){;} ----内联函数

内联函数对比普通函数的区别以及优缺点:

区别:如图两个程序。
普通函数在主函数执行到max(1,2)的时候,会跳转去寻找max函数的入口,然后带入参数执行函数,执行完毕后,再回到主函数接下来的代码。
内联函数在主函数执行到max(1,2)的时候,会使用max函数的代码来直接替换掉main函数的max(1,2)代码。
c++中的内联函数_第1张图片
c++中的内联函数_第2张图片
内联函数的优点:省去了进出函数的开销,执行速度更快。

内联函数的缺点:如果函数体的代码很多很复杂,进出函数的开销远远小于执行函数体的开销,使用内联函数会是程序代码量和执行速度更慢。

总结:在使用内联函数的时候为了规避内联函数可能的缺点,内联函数的代码一般不超过10行,并且不包含复杂语法。

内联函数和define对比:
虽然内联函数和define都是在编译时替换代码,但是有如下区别:
1.内联函数的调用是传参,宏定义只是简单的文本替换,简单的文本替换可能带来很多问题,最常见的就是赋值语句(也就是等号)的两端都用到了变量,并且一段还改变了变量值,那么
c++中的内联函数_第3张图片
上面这一条尤其针对迭代器变量和指针变量。

另外就是重复的问题,例如在如下代码中,输出为11和13(b被加了两次),而使用内联函数输出则为11和12。
c++中的内联函数_第4张图片

2.内联函数可以在程序运行时调用,宏定义是在程序编译进行

3.内联函数有类型检测更加的安全,宏定义没有类型检测

你可能感兴趣的:(c++)