C++中内联函数的定义和使用
来源:互联网 发布:用记事本写java 编辑:程序博客网 时间:2024/05/16 10:16
引入内联函数的目的是为了解决程序中函数调用的效率问题。
函数是一种更高级的抽象。它的引入使得编程者只关心函数的功能和使用方 法,而不必关心函数功能的具体实现;函数的引入可以减少程序的目标代码,实 现程序代码和数据的共享。但是,函数调用也会带来降低效率的问题,因为调用 函数实际上将程序执行顺序转移到函数所存放在内存中某个地址,将函数的程序 内容执行完后,再返回到转去执行该函数前的地方。这种转移操作要求在转去前 要保护现场并记忆执行的地址,转回后先要恢复现场,并按原来保存地址继续执 行。因此,函数调用要有一定的时间和空间方面的开销,于是将影响其效率。特 别是对于一些函数体代码不是很大,但又频繁地被调用的函数来讲,解决其效率 问题更为重要。引入内联函数实际上就是为了解决这一问题。
在程序编译时,编译器将程序中出现的内联函数的调用表达式用内联函数的 函数体来进行替换。显然,这种做法不会产生转去转回的问题,但是由于在编译 时将函数休中的代码被替代到程序中,因此会增加目标程序代码量,进而增加空 间开销,而在时间代销上不象函数调用时那么大,可见它是以目标代码的增加为 代价来换取时间的节省。
内联函数的定义方法
定义内联函数的方法很简单,只要在函数定义的头前加上关键字inline即可 。内联函数的定义方法与一般函数一样。如:
inline int add_int (int x, int y, int z)
{
return x+y+z;
}
在程序中,调用其函数时,该函数在编译时被替代,而不是像一般函数那样 是在运行时被调用。
使用内联函数应注意的事项
内联函数具有一般函数的特性,它与一般函数所不同之处公在于函数调用的 处理。一般函数进行调用时,要将程序执行权转到被调用函数中,然后再返回到 调用它的函数中;而内联函数在调用时,是将调用表达式用内联函数体来替换。 在使用内联函数时,应注意如下几点:
1.类内定义的函数是内联函数,类外定义的函数是非内联函数(短函数可以 定义在类内,长函数可以定义在类外)。
2.可以为类外定义的函数指定 inline 关键字,强行为内联函数。
3.在内联函数内不允许用循环语句和开关语句。
4.内联函数的定义必须出现在内联函数第一次被调用之前。
- C++中内联函数的定义和使用
- C++中内联函数的定义和使用
- C++中,内联函数和宏定义的区别是什么?
- C++中,内联函数和宏定义的区别是什么?
- 宏定义和内联函数的学习
- 内联函数和宏定义的区别
- 内联函数的声明和定义
- 内联函数和宏定义的差别
- 内联函数的声明和定义位置
- 内联函数和宏定义的区别
- 内联函数和宏定义的区别
- 内联函数和宏定义的区别
- 宏定义和内联函数的区别
- 内联函数和宏定义的区别
- 内联函数和宏定义的区别
- 内联函数和宏定义的区别
- 内联函数和宏定义的区别
- 内联函数和宏定义的区别
- 写个码农们:从业互联网13年,才觉得卖卤菜比找风投上市靠谱只看楼主
- 格式化sqlplus查询结果集
- IT行业干什么最赚钱
- C++ 初始化列表
- ORACLE RMAN 跨平台恢复测试(Windows->Linux)
- C++中内联函数的定义和使用
- 代理模式
- Hadoop学习
- Hadoop主要子项目
- mysql 命令
- js的Prototype属性解释及常用方法
- java的(PO,VO,TO,BO,DAO,POJO)解释
- VMware Workstation CentOS的安装问题
- MySQL语句