C++语言支持函数内联,其目的是为了提高函数的执行效率(速度).

宏的优点

在C程序中,可以用宏代码提高执行效率。

编译预处理器用拷贝宏代码的方式取代函数调用,省去了参数压栈,生成汇编语言的CALL调用、返回参数、执行return等过程,从而提高了速度。

宏的缺点

1、最大缺点是容易出错,预处理器在拷贝宏代码的时候常常产生意向不到的边际效应。

2、不可调试

3、在C++中,宏代码还有另外一种缺点:无法操作类的私有数据成员。

第一种情况见下面示例:

#define MAX(a,b) (a)>(b)?(a):(b)
//语句:
result = MAX(i,j) + 2;
//将被预处理器扩展为:
result = (i)>(j)?(i):(j) + 2;
//由于运算符”+“比运算符”?:“的优先级高,所以上述语句并不等价于期望的:
result = ((i)>(j)?(i):(j)) + 2; //如果把宏代码改写为:
#define MAX(a,b) ((a)>(b)?(a):(b))
//则可以解决由优先级引起的错误。但是即使使用修改后的宏代码也不是万无一失的,例如:
result = MAX(i++,j);
//将被预处理器解释为:
result = ((i++)>(j)?(i++):(j));

用函数内联取代宏  

  • 内联函数的优点
  1. 内联函数既具备宏代码的效率,又增加了安全性,而且可以自由操作类的数据成员。
//例如,声明以下内联函数:
inline const string &shorterString(const string &s1, const string &s2)
{
return s1.size() <= s2.size() ? s1 : s2;
} //调用如下:
cout << shortString(s1, s2) <<endl; //在编译的过程中展开如下:
cout << s1.size() <= s2.size() ? s1 : s2 << endl; //从上面可以看出内联省去了参数压栈,跳转,退栈和返回等操作
//从而消除了shortString函数的运行时开销

  

2.函数被内联后,编译器可以通过上下文相关的优化技术对结果代码执行更深入的优化,而这种优化在普通函数体内是无法单独进行的,因为一旦进入函数体内它也就脱离了调用环境的上下文

  • 内联函数的编程风格

  关键字inline必须与函数定义体放在一起才能使函数真正的内联,仅把inline放在函数声明的前面不起任何作用。

  所以说inline是“用于实现的关键字”,而不是一种“用于声明的关键字”.

//此情况Foo不能成为内联函数
inline void Foo(int x,int y);//inline 仅与函数声明放在一起
void Foo(int x,int y)
{
...
} //此情况Foo会成为内联函数
void Foo(int x,int y);//inline 仅与函数声明放在一起
inline void Foo(int x,int y)
{
...
}

  

  • 内联函数的缺点
  1. 滥用内联会造成代码膨胀,因为编译器会在调用位置拷贝出函数体,从上面的例子可以看出

内联机制用于优化规模较小,流程直接,频繁调用的函数。

  • 如果函数体内的代码过长,使用内联将导致可执行代码膨胀过大
  • 如果函数体内出现循环或者其他复杂的控制结构,那么执行函数体内代码的时间比函数调用开销大的多,因此内联的意义不大

函数内联inline的更多相关文章

  1. 函数内联 inline,__inline,__forceinline

    ▶ 感谢大佬的总结[http://www.cnblogs.com/xuemaxiongfeng/articles/2464850.html] ● 存储限定符 __inline 与关键字 inline ...

  2. C++ 内联(inline)函数

    目录 内联函数的使用方法 内联函数的使用规则 使用inline的时机 inline函数与宏函数的差异 inline是C++关键字,在函数声明或定义中,函数返回类型前加上关键字inline,即可以把函数 ...

  3. C/C++中内联(inline)函数的优点和缺点

    优点 缺点 1. 内联函数代码被放入符号表中,在使用时进行替换,和宏展开一样,效率很高: 1. 不允许过多的代码,代码过多的话会造成大的内存消耗,最好在5行以内: 2. 编绎器在调用一个内联函数,首先 ...

  4. 宏 函数 内联函数inline

    带参宏有时候可以代替函数作用:优点直接替代,省去函数调用过程的开销:但缺点也是很明显:容易出错,系统不做检查非常容易出错. 改进方案:内联函数:既有带参宏的直接替代(拷贝)的优点,又有系统检查的优点. ...

  5. [ 随手记 1 ] C/C++宏,普通函数,内联函数

    函数定义 C 语言中的函数定义的一般形式如下: return_type function_name( parameter list ) { body of the function } 在 C 语言中 ...

  6. C++ 函数 内联函数

    内联函数的功能和预处理宏的功能相似,在介绍内联函数之前,先介绍一下预处理宏.宏是简单字符替换,最常见的用法:定义了一个代表某个值的全局符号.定义可调用带参数的宏.作为一种约定,习惯上总是用大写字母来定 ...

  7. c++内联 inline

    内联声明只是建议 ,不一定就会内联. http://www.voidcn.com/blog/u011327981/article/p-5006835.html

  8. 内联函数 inline

    (一)inline函数(摘自C++ Primer的第三版) 在函数声明或定义中函数返回类型前加上关键字inline即把min()指定为内联. inline int min(int first, int ...

  9. 内联函数 inline 漫谈

    内联函数存在的结论是: 引入内联函数是为了解决函数调用效率的问题 由于函数之间的调用,会从一个内存地址调到另外一个内存地址,当函数调用完毕之后还会返回原来函数执行的地址.函数调用会有一定的时间开销,引 ...

随机推荐

  1. [转]SQL Server 数据库定时自动备份

    前提:在使用下面的备份方式之前需要确保你的Sqlserver Agent服务启动,切设置为自动启动.否则当你服务器重启了但是Agent服务没有启动,那么自动备份任务就不会执行 (一)使用TSql代码自 ...

  2. 超强IIS站点工具一键设置PHP,支持多个PHP同时运行

    PHPWAMP8.8.8.8IN支持三大主流Web服务器:iis.apache.nginx NGINX站点管理.IIS站点管理.Apache站点管理均支持php多版本同时运行,无限自定义mysql.p ...

  3. Java基础 之软引用、弱引用、虚引用 ·[转载]

    Java基础 之软引用.弱引用.虚引用 ·[转载] 2011-11-24 14:43:41 Java基础 之软引用.弱引用.虚引用 浏览(509)|评论(1)   交流分类:Java|笔记分类: Ja ...

  4. codeforces 741D Arpa’s letter-marked tree and Mehrdad’s Dokhtar-kosh paths(启发式合并)

    codeforces 741D Arpa's letter-marked tree and Mehrdad's Dokhtar-kosh paths 题意 给出一棵树,每条边上有一个字符,字符集大小只 ...

  5. Alpha 冲刺报告(2/10)

    Alpha 冲刺报告(2/10) 队名:洛基小队 团队困难汇总:在开始正式编码的时候遇到了很严重的问题,Cocos Creator的教程过少,之前浏览的官网上的教程以为很齐全,但是在最重要的脚本方面还 ...

  6. 【cs231n】图像分类 k-Nearest Neighbor Classifier(K最近邻分类器)【python3实现】

    [学习自CS231n课程] 转载请注明出处:http://www.cnblogs.com/GraceSkyer/p/8763616.html k-Nearest Neighbor(KNN)分类器 与其 ...

  7. SGU---104 DP

    题目链接: https://cn.vjudge.net/problem/SGU-104 题目大意: 假设你想以最美观的方式布置花店的橱窗,你有F束花,每束花的品种都不一样,同时,你至少有同样数量的花瓶 ...

  8. Spring AbstractApplicationContext抽象类的refresh()方法--笔记

    Spring中AbstractApplicationContext抽象类的refresh()方法是用来刷新Spring的应用上下文的.下面Spring的应用上下文我都叫作context @Overri ...

  9. 【bzoj 4589】Hard Nim

    题目 根据我为数不多的博弈知识我发现需要求多少种方案使得异或和为\(0\) 非常显然就是构造出那个质数多项式\(F\),答案就是\(F^n(0)\),当然这里是异或卷积 于是美滋滋的敲上去一个多项式快 ...

  10. 【洛谷】【线段树】P1886 滑动窗口

    [题目描述:] 现在有一堆数字共N个数字(N<=10^6),以及一个大小为k的窗口.现在这个从左边开始向右滑动,每次滑动一个单位,求出每次滑动后窗口中的最大值和最小值. [输入格式:] 输入一共 ...