这里先说一下函数调用的实现过程:
- 执行函数调用指令时,程序将立即存储该指令的内存地址
- 将函数参数复制到堆栈(把该函数内存块保存一下)
- 跳到该函数的起点内存地址,执行该函数(可能还需要把返回值放入寄存器中)
- 最后跳回函数调用指令的存储地址
由上面函数调用步骤来看,函数调用过程中的来回跳转需要一定的时间开销,内联函数就是用来减少这部分的时间开销来加快函数运行速度。
对于内联函数,程序无须调到另一个位置来执行代码再跳回来,内联函数的运行速度比常规函数稍快,但代价是需要占用更多内存空间。如果代码执行时间很短,则内联调用就可以节省大部分时间。但是由于这个过程相当快,尽管节省了该过程的大部分时间,但节省的时间绝对值并不大。
使用内联函数:
函数声明前加关键字inline 或 函数定义前加关键字inline
大部分时候我们使用后者
程序员在请求使用内联函数的时候,编译器并不一定会满足这种需求,在它认为函数中调用自己的时候不能将其作为内联函数(内联函数不能递归)。