当前位置: 首页 > 编程笔记 >

C++中inline函数详解

李意致
2023-03-14
本文向大家介绍C++中inline函数详解,包括了C++中inline函数详解的使用技巧和注意事项,需要的朋友参考一下

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

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

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

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

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

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

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

三、inline函数的使用场合

示例代码:

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

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

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

函数的代码量比较大时,使用inline函数会使内存消耗代价较高。
函数体内出现循环,那么执行函数的时间要比函数调用的开销大。
另外,类的构造函数和析构函数容易让人误解成使用inline更有效。要当心构造函数和析构函数可能会隐藏一些行为,如“偷偷地执行基类或成员对象的构造函数和析构函数。”
一个好的编译器会根据函数体,自动取消不适合的inline函数。(说明了,inline不应该出现在类的内部,及函数的声明的部分)

五、inline函数与宏的区别?

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

以上所述就是本文的全部内容了,希望大家能够喜欢。

 类似资料:
  • # 强制函数永远以inline的形式调用 例子 #if defined(__GNUC__) #define FORCEDINLINE __attribute__((always_inline)) #else #define FORCEDINLINE #endif FORCEDINLINE int add(int a,int b) { return a+b; } 技巧 上面的例子是gc

  • C ++ inline函数是通常用于类的强大概念。 如果函数是内联函数,则编译器会在编译时调用函数的每个位置放置该函数的代码副本。 对内联函数的任何更改都可能需要重新编译函数的所有客户端,因为编译器需要再次替换所有代码,否则它将继续使用旧功能。 要内联函数,请在函数名称前面放置关键字inline ,并在对函数进行任何调用之前定义函数。 如果定义的函数超过一行,编译器可以忽略内联限定符。 类定义中的

  • 主要内容:1、函数声明,2、函数调用,3、没有参数和返回值的函数,4、有参数但没有返回值的函数,5、有参数且有返回值的函数,6、类中的静态函数C# 中的函数(也可以称为方法)是一段具有签名(由函数名、参数类型和参数修饰符组成的函数信息)的代码块,可以用来实现特定的功能。一般情况下一个函数由以下几个部分组成: 访问权限修饰符:用于指定函数对一个类的可见性; 返回值类型:用于指定函数返回值的数据类型; 函数名称:用于进行函数调用的唯一名称; 参数列表:在调用函数时需要传递给函数的参数,参数列表是可选

  • 主要内容:C++ 是如何做到函数重载的在实际开发中,有时候我们需要实现几个功能类似的函数,只是有些细节不同。例如希望交换两个变量的值,这两个变量有多种类型,可以是 int、float、char、bool 等,我们需要通过参数把变量的地址传入函数内部。在C语言中,程序员往往需要分别设计出三个不同名的函数,其函数原型与下面类似: 但在 C++中,这完全没有必要。C++ 允许多个函数拥有相同的名字,只要它们的参数列表不同就可以,这就是 函数

  • 本文向大家介绍详解C语言中的getgrgid()函数和getgrnam()函数,包括了详解C语言中的getgrgid()函数和getgrnam()函数的使用技巧和注意事项,需要的朋友参考一下 C语言getgrgid()函数:从组文件中取得指定gid的数据 头文件: 定义函数: 函数说明:getgrgid()用来依参数gid 指定的组识别码逐一搜索组文件, 找到时便将该组的数据以group 结构返回

  • 本文向大家介绍详解C语言中的fopen()函数和fdopen()函数,包括了详解C语言中的fopen()函数和fdopen()函数的使用技巧和注意事项,需要的朋友参考一下 C语言fopen()函数:打开一个文件并返回文件指针 头文件: fopen()是一个常用的函数,用来以指定的方式打开文件,其原型为:   【参数】path为包含了路径的文件名,mode为文件打开方式。 mode有以下几种方式: