Chinaunix首页 | 论坛 | 博客
  • 博客访问: 230705
  • 博文数量: 75
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 848
  • 用 户 组: 普通用户
  • 注册时间: 2013-10-08 10:27
文章分类
文章存档

2014年(9)

2013年(66)

我的朋友

分类: C/C++

2013-11-05 17:16:30

1.1定义简介


内联函数从源代码层看,有函数的结构,而在编译后,却不具备函数的性质。内联函数不是在调用时发生控制转移,而是在编译时将函数体嵌入在每一个调用处。编译时,类似宏替换,使用函数体替换调用处的函数名。一般在代码中用inline修饰,但是能否形成内联函数,需要看编译器对该函数定义的具体处理。带有参数的宏定义中不含有类型名称,多行语句一般使用do while语句,例如:
[cpp] view plaincopy
3 #define  AddToHere(mynode,parentnode,child)\  
4 do{\  
5     (mynode)->parent=(parentnode);\  
6     (parentnode)->child=(mynode);\  
7 }while(0)  




1.2注意事项


1).递归函数不能定义为内联函数
2).内联函数一般适合于不存在while和switch等复杂的结构且只有1~5条语句的小函数上,否则编译系统将该函数视为普通函数。
3).内联函数只能先定义后使用,否则编译系统也会把它认为是普通函数。


2.宏


2.1宏定义的缺陷


1).宏不能访问对象的私有成员。
2).宏的定义很容易产生二义性。


2.2宏定义的常见二义性
1)没有给参数加括号从而导致的优先级混乱
2)在传递参数的时候使用了表达式,表达式中含有++运算,从而导致的参数失真


3.二者的区别


内联函数和宏的区别在于,宏是由预处理器对宏进行替代,而内联函数是通过编译器控制来实现的。而且内联函数是真正的函数,只是在需要用到的时候,内联函数像宏一样的展开,所以取消了函数的参数压栈,减少了调用的开销。你可以象调用函数一样来调用内联函数,而不必担心会产生于处理宏的一些问题。
阅读(877) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~