【C++】内联函数

函数调用的实现过程:

执行函数调用指令时,程序将立即存储该指令的内存地址
将函数参数复制到堆栈(把该函数内存块保存一下)
跳到该函数的起点内存地址,执行该函数(可能还需要把返回值放入寄存器中)
最后跳回函数调用指令的存储地址
由上面函数调用步骤来看,函数调用过程中的来回跳转需要一定的时间开销,内联函数就是用来减少这部分的时间开销来加快函数运行速度。

对于内联函数,程序无须调到另一个位置来执行代码再跳回来,内联函数的运行速度比常规函数稍快,但代价是需要占用更多内存空间。如果代码执行时间很短,则内联调用就可以节省大部分时间。但是由于这个过程相当快,尽管节省了该过程的大部分时间,但节省的时间绝对值并不大。

使用内联函数:

函数声明前加关键字inline 或 函数定义前加关键字inline

大部分时候我们使用后者

程序员在请求使用内联函数的时候,编译器并不一定会满足这种需求,在它认为函数中调用自己的时候不能将其作为内联函数(内联函数不能递归)。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章