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. 转:Eclipse+webservice开发实例

    原文地址:http://blog.csdn.net/xw13106209/article/details/7049614 1.参考文献: 1.利用Java编写简单的WebService实例  http ...

  2. ms17-010漏洞利用教程

    ms17-010 漏洞利用并拿下服务器教程 攻击环境: 攻击机win2003 ip:192.168.150.129 Window2003 Python环境及工具 攻击机kali: ip:192.168 ...

  3. December 01st 2016 Week 49th Thursday

    Life is a maze and love is a riddle. 生活是个迷宫,爱情是个谜语. I am lost in both. Can you provide me some guida ...

  4. RTCM32转码至RTCM23,再次测试,一些收获

    RTCM32是2013年发布的,RTCM23是2001年发布,两者相隔十多年,某些软件已经不支持RTCM32的解码.故在此对RTCM32的编码进行转换,使用2018年4月9日天宝接收机数据.编码格式为 ...

  5. 一个最简单的WebSocket hello world demo

    服务器端代码不超过42行: const WSServer = require("./server.js"); var counter = 0; function createWeb ...

  6. 关于markdown格式的测试..

    标题 标题一 这是? 标题二 标题三 标题四 区块 1.这是一个列表项目 还是吗? 嵌套了? 空格了? 区块加列表 标题加二级列表 嘿嘿 无序列表 RED GREEN BLUE 有序列表 dog ca ...

  7. 【linux】安装和配置 mysql服务器

    按照官网教程,根据自己的系统安装不同的发行版 https://dev.mysql.com/doc/refman/5.6/en/linux-installation-yum-repo.html 配置: ...

  8. JavaScript中烧脑的&&和||

    在js中经常能看到以下的写法: var obj1 = a || b || c; var obj2 = a && b && c; 刚看到时,很容易认为返回的两个变量都是 ...

  9. BZOJ4180:字符串计数(SAM,二分,矩阵乘法)

    Description SD有一名神犇叫做Oxer,他觉得字符串的题目都太水了,于是便出了一道题来虐蒟蒻yts1999. 他给出了一个字符串T,字符串T中有且仅有4种字符 'A', 'B', 'C', ...

  10. leetcode 141. Linked List Cycle 、 142. Linked List Cycle II

    判断链表有环,环的入口结点,环的长度 1.判断有环: 快慢指针,一个移动一次,一个移动两次 2.环的入口结点: 相遇的结点不一定是入口节点,所以y表示入口节点到相遇节点的距离 n是环的个数 w + n ...