博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
内联函数提高函数调用效率
阅读量:3591 次
发布时间:2019-05-20

本文共 564 字,大约阅读时间需要 1 分钟。

一、函数调用:

函数调用的实质是,将程序执行的顺序转移到被调用的函数所在的内存地址,将函数执行完后,再返回到原来的地址继续往下执行,因此需要保护现场并记忆执行的地址,还要恢复现场。即不断地有函数入栈,会造成栈空间或栈内存的大量消耗。栈空间是指放置函数内数据的内存空间,是有限的,假如频繁大量的使用就会造成因栈空间不足所造成的程序出错问题。而且,函数调用需要消耗一定的时间和空间,于是影响了效率。

二、频繁调用:

一些函数不大,但需要频繁地调用时,效率很低。引入内联函数为了提高程序中函数调用的效率。

三、内联函数:

程序编译时,遇到调用的内联函数时,只是将函数名替换为内联函数的函数体,这样执行时就不需要再去调用函数。但是会增加目标代码量,进而增加空间开销。所以,它是牺牲空间换取时间的节省。

内联函数跟普通函数一样,只是需要在函数名前加一个关键字inline关键字inline 必须与函数定义体放在一起才能使函数成为内联,仅将inline放在函数声明前面不起任何作用。

例如:

inline int add(int a,int b)

{

return a+b;

}

注:内联函数一般只是简单的一两句,不能有循环语句和开关语句(switch case),如果过于复杂,编译器则会按照普通函数对待,不会当做内联函数,也不会报错。

转载地址:http://hatwn.baihongyu.com/

你可能感兴趣的文章
windows下pip镜像源换成清华镜像
查看>>
python pip命令下载不了解决办法,python特殊包的下载
查看>>
Chrome正在受到自动软件的控制 解决办法
查看>>
selenium定位的使用
查看>>
selenium定位的实例
查看>>
html文档为uincode编码的解码问题
查看>>
urllib.request.urlretrieve
查看>>
python文本相似度分析tf-idf
查看>>
sklearn无监督学习-聚类k-means
查看>>
树莓派中文输入法
查看>>
sklearn-降维-(主成分分析)PCA
查看>>
sklearn-降维-非负矩阵分解(NMF)
查看>>
windows局域网、校园网连接树莓派
查看>>
Django的URL路由
查看>>
django的视图响应类型
查看>>
Django的模板引擎与模板使用
查看>>
liunx安装chrome浏览器
查看>>
tensorflow矩阵的运算
查看>>
tensorflow更新变量
查看>>
sublime 显示文件编码
查看>>