定义
内联函数从源代码层看,有函数的结构,而在编译后,却不具体函数的性质。编译时,类似宏替换地, 使用函数体替换调用处的函数名。 一般在代码中用inline修饰,但是否能形成内联函数,需要看编译器对该函数定义的具体处理。
实现
有两种实现方式:
1.在类声明的内部声明,而在类声明外部定义叫做显式内联函数 ,如:
class display
{
int t;
public:
void output(void)
}
display object;
inline void display::output(void)
{
cout << "i is " << i <<"/n";
}
如果在声明函数时加上inline,则在外部定义时可以省略inline;如果声明时没有加inline,则在外部定义时加上inline
2.在类声明的内部定义,叫做隐式内联函数 ,如:
class display
{
int t;
public:
inline void output(void) //对于在类声明内部定义的函数,如果没加inline,自动作为inline处理
{
cout<<"i is "<< i << "/n";
}
}
实际应用
引入内联函数的目的是为了解决程序中函数调用的效率问题。
函数是一种更高级的抽象。它的引入使得编程者只关心函数的功能和使用方法,而不必关心函数功能 的具体实现;函数的引入可以减少程序的目标代码,实现程序代码和数据的共享。但是,函数调用也会带来降低效率的问题,因为调用函数实际上将程序执行顺序转 移到函数所存放在内存中某个地址,将函数的程序内容执行完后,再返回到转去执行该函数前的地方。这种转移操作要求在转去前要保护现场并记忆执行的地址,转 回后先要恢复现场,并按原来保存地址继续执行。因此,函数调用要有一定的时间和空间方面的开销,于是将影响其效率。特别是对于一些函数体代码不是很大,但 又频繁地被调用的函数来讲,解决其效率问题更为重要。引入内联函数实际上就是为了解决这一问题。
在程序编译时,编译器将程序中出现的内联函数的调用表达式用内联函数的函数体来进行替换。显 然,这种做法不会产生转去转回的问题,但是由于在编译时函数体中的代码被替代到程序中,因此会增加目标程序代码量,进而增加空间开销,而在时间开销上不象 函数调用时那么大,可见它是以目标代码的增加为代价来换取时间的节省。
在程序中,调用其函数时,该函数在编译时被替代,而不是像一般函数那样是在运行时被调用。
注意事项
使用内联函数应注意的事项
内联函数具有一般函数的特性,它与一般函数所不同之处只在于函数调用的处理。一般函数进行调用 时,要将程序执行权转到被调用函数中,然后再返回到调用它的函数中;而内联函数在调用时,是将调用表达式用内联函数体来替换。在使用内联函数时,应注意如 下几点:
1.在内联函数内不允许用循环语句和开关语句。
如果内联函数有这些语句,则编译将该函数视同普通函数那样产生函数调用代码,递归函数(自己调 用自己的函数)是不能被用来做内联函数的。内联函数只适合于只有1~5行的小函数。对一个含有许多语句的大函数,函数调用和返回的开销相对来说微不足道, 所以也没有必要用内联函数实现。
2.内联函数的定义必须出现在内联函数第一次被调用之前。
3.所有在类说明内部定义的函数自动作为inline处理。
内联函数应该放在头文件中定义,这一点不同于其它函数。把内联函数的定义放在头文件中,可以确保在调用函数时所使用的定义是相同的,并且保证在调用点该函数的定义对编译器可见。不在类定义体内定义的inline函数,其定义通常应放在有类定义的同一头文件中。