首先我们一起简单回顾一下函数调用的过程:
我们知道,每个函数名就代表了该函数的起始地址,当该函数被调用的时,主调函数保存现场,然后跳到被调用的函数地址开始执行。
被调用的函数执行完毕之后,通过之前保存的现场信息,返回到原来的地址继续执行后面的代码(指令)。
通过上面的记述我们可以知道,在函数调用过程中发声了地址间的切换,这样以来,肯定会降低函数执行的时间效率。有没有更好的方法来提 高实践效率呢?答案:有,内联函数的出现在一定程度上就解决了时间效率的问题,但是却是以牺牲了空间效率为前提的,下面我们来看 看内联函数的本质。
内联函数是这样一种函数:即其编译后的代码与其他程序代码“内联”起来了。也就是说编译器将使用相应的函数代码替换函数调用。讲到这里就有了一个疑问:内联函数那不就是宏函数么?关于这两者之间的区别我们稍后再做解释。
一 内联函数的使用方法:
a.在函数声明前加上关键字 inline
b.在函数定义前加上关键字 inline
注意:内联函数不能递归调用(编译器不允许),同时我们定义的内敛函数一般都要求简短,这样才能真正达到节省时间的目的
二 代码演示:
——————————————————————————————————————————————————
#include <iostream>
using namespace std;
//an inline funcion definition
inline double square(double x)
{
return x*x;
}
int main()
{
double a;
double b = 2.0;
a = square(b);
cout << "The value of a now is " << a <<"/n"
return 0;
}
——————————————————————————————————————————————————
三 内联函数与C语言中的宏定义
综合起来,主要有方面的区别
a. 替换的时间:宏函数是在预编译阶段执行代码替换的,而内敛函数是在编译的过程中执行代码替换的
b. 替换的性质:宏函数的替换仅仅只是文本替换而已,而内敛函数的替换是真正意义上的代码替换。
距离来说明区别b:
宏/内联函数在被调用时,如果参数是一个表达式,宏函数则是进行简单的表达式替换,而内联函数则是先计算表达式的值,然后传递给函数,这点就跟普通的函数调用时相同的了,所以这种情况下使用宏函数是非常危险的。
综上,我们建议在C++下,尽量使用内联函数而非宏函数。