c++中的内联函数

c++中的内联函数,第1张

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

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

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

区别:如图两个程序。
普通函数在主函数执行到max(1,2)的时候,会跳转去寻找max函数的入口,然后带入参数执行函数,执行完毕后,再回到主函数接下来的代码。
内联函数在主函数执行到max(1,2)的时候,会使用max函数的代码来直接替换掉main函数的max(1,2)代码。


内联函数的优点:省去了进出函数的开销,执行速度更快。

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

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

内联函数和define对比:
虽然内联函数和define都是替换代码,但是有如下区别:
1.内联函数的调用是传参,宏定义只是简单的文本替换,例如在如下代码中,输出为11和13(b被加了两次),而使用内联函数输出则为11和12。

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

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

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

原文地址:https://www.54852.com/langs/728664.html

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

发表评论

登录后才能评论

评论列表(0条)

    保存