• C++ inline函数


    本文主要记录了C++中的inline函数,也就是内联函数,主要记录了以下几个问题:

    1. C++为什么引入inline函数?
    2. 为什么inline能很好的取代表达式形式的预定义?
    3. inline函数的使用场合
    4. 为什么不把所有的函数定义成inline函数?
    5. inline函数与宏的区别?

    一、C++为什么引入inline函数?

    主要目的:用它代替C语言中表达式形式的宏定义来解决程序中函数调用的效率问题。

    C语言中的宏定义:#define ExpressionName(var1,var2) (var1+var2)*(var1-var2)这种宏定义,它使用预处理器实现,没有了参数压栈、代码生成等一系列得到操作,因此效率很高。但缺点如下:

    • 仅仅是做预处理器符号表中的简单替换,因此不能进行参数有效性的检测,不能享受C++编译器严格类型检查的好处。
    • 另外,它的返回值也不能被强制转换为可转换的合适类型。
    • 还有,C++引入了类及类的访问控制,这样,如果一个操作或者说一个表达式涉及类的保护成员或者私有成员,这种宏定义就无法实现(因为无法将this指针放在合适的位置上)

    二、为什么inline能很好的取代表达式形式的预定义?

    • inline定义类的内联函数,函数的代码被放入符号表中,在使用时直接进行替换(像宏一样展开)没有了调用的开销,效率也高了。
    • 类的内联函数也是一个真正的函数。编译器在调用一个内联函数的时候,首先进行一系列的检测(参数的类型)
    • inline函数可以作为某个类的成员函数,这就可以在其中使用该类的保护成员和私有成员。

    三、inline函数的使用场合

    示例代码:

    Image 2

    由上述示例代码可知:A类的2个成员函数都是inline函数,readTest()函数的定义在类内,所以自动转化为inline函数,setTest()函数的定义在类外,所以必须加inline关键字。类的成员常定义成保护和私有的,外界不能直接访问这些成员,所以必须有成员接口函数来访问。这些接口函数被定义成inline函数,会获得比较好的效果。所以,inline函数常用于定义存取函数(代码简短),inline函数的效率比较高。


    四、为什么不把所有的函数定义成inline函数?

    inline是以代码的膨胀(复制)为待见的,仅仅省去了函数调用的开销,从而提高了函数的执行效率。如果,执行函数体内代码的时间相比于函数调用的开销大,那么效率的收获会很少。另一方面,每一个inline函数的调用都要复制代码,使程序的总代码量增大,消耗更多的内存空间。
    所以:

    • 函数的代码量比较大时,使用inline函数会使内存消耗代价较高。
    • 函数体内出现循环,那么执行函数的时间要比函数调用的开销大。
    • 另外,类的构造函数和析构函数容易让人误解成使用inline更有效。要当心构造函数和析构函数可能会隐藏一些行为,如“偷偷地执行基类或成员对象的构造函数和析构函数。”

    一个好的编译器会根据函数体,自动取消不适合的inline函数。(说明了,inline不应该出现在类的内部,及函数的声明的部分)


    五、inline函数与宏的区别?

    1. inline是在 编译 时展开的,而宏是在 预编译 时展开的。
    2. 在编译时,inline函数可以直接嵌套到目标代码里,而宏只是简单地文本替换
    3. inline函数可以完成类型和语句是否正确,而宏不具有这样的功能。
    4. inline函数是函数,而宏不是函数。
    5. 宏的定义时,小心参数的处理(一般把参数用括号括起来),否则会引起二义性,而inline函数不用担心二义性。

  • 相关阅读:
    正则表达式
    request库解析
    urllib库解析
    爬虫入门基本原理
    图的遍历dfs和bfs
    KMP算法
    Linux操作系统实验-线程同步
    Leetcode 183场周赛
    并查集--Disjoint Set
    C#杂乱知识汇总
  • 原文地址:https://www.cnblogs.com/zi-xing/p/4621069.html
Copyright © 2020-2023  润新知