background image

内联函数

 

    引入内联函数的目的是为了解决程序中函数调用的效率问题。

    函数是一种更高级的抽象。它的引入使得编程者只关心函数的功能和使用方法,

而不必关心函数功能的具体实现;函数的引入可以减少程序的目标代码,实现程

序代码和数据的共享。但是,函数调用也会带来降低效率的问题,因为调用函数实
际上将程序执行顺序转移到函数所存放在内存中某个地址,将函数的程序内容执

行完后,再返回到转去执行该函数前的地方。这种转移操作要求在转去前要保护现
场并记忆执行的地址,转回后先要恢复现场,并按原来保存地址继续执行。因此,

函数调用要有一定的时间和空间方面的开销,于是将影响其效率。特别是对于一些
函数体代码不是很大,但又频繁地被调用的函数来讲,解决其效率问题更为重要。

引入内联函数实际上就是为了解决这一问题。

    在程序编译时,编译器将程序中出现的内联函数的调用表达式用内联函数的函

数体来进行替换。显然,这种做法不会产生转去转回的问题,但是由于在编译时将

函数休中的代码被替代到程序中,因此会增加目标程序代码量,进而增加空间开
销,而在时间代销上不象函数调用时那么大,可见它是以目标代码的增加为代价

来换取时间的节省。

内联函数的定义方法

    定义内联函数的方法很简单,只要在函数定义的头前加上关键字 inline 即可。内

联函数的定义方法与一般函数一样。如:

    inline int add_int (int x, int y, int z)

    {
      return x+y+z;

    }

    在程序中,调用其函数时,该函数在编译时被替代,而不是像一般函数那样是

在运行时被调用。

使用内联函数应注意的事项

    内联函数具有一般函数的特性,它与一般函数所不同之处公在于函数调用的处

理。一般函数进行调用时,要将程序执行权转到被调用函数中,然后再返回到调用
它的函数中;而内联函数在调用时,是将调用表达式用内联函数体来替换。在使用

内联函数时,应注意如下几点:

    1.在内联函数内不允许用循环语句和开关语句。
    2.内联函数的定义必须出现在内联函数第一次被调用之前。
    3.本栏目讲到的类结构中所有在类说明内部定义的函数是内联函数。