这里先说一下函数调用的实现过程:
执行函数调用指令时,程序将立即存储该指令的内存地址
将函数参数复制到堆栈(把该函数内存块保存一下)
跳到该函数的起点内存地址,执行该函数(可能还需要把返回值放入寄存器中)
最后跳回函数调用指令的存储地址
由上面函数调用步骤来看,函数调用过程中的来回跳转需要一定的时间开销,内联函数就是用来减少这部分的时间开销来加快函数运行速度。
对于内联函数,程序无须调到另一个位置来执行代码再跳回来,内联函数的运行速度比常规函数稍快,但代价是需要占用更多内存空间。如果代码执行时间很短,则内联调用就可以节省大部分时间。但是由于这个过程相当快,尽管节省了该过程的大部分时间,但节省的时间绝对值并不大。
使用内联函数:
函数声明前加关键字inline 或 函数定义前加关键字inline
大部分时候我们使用后者
程序员在请求使用内联函数的时候,编译器并不一定会满足这种需求,在它认为函数中调用自己的时候不能将其作为内联函数(内联函数不能递归)。
总结以上是内存溢出为你收集整理的C++内联函数全部内容,希望文章能够帮你解决C++内联函数所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)