1.宏
1.1定义简介
内联函数从源代码层看,有函数的结构,而在编译后,却不具备函数的性质。内联函数不是在调用时发生控制转移,而是在编译时将函数体嵌入在每一个调用处。编译时,类似宏替换,使用函数体替换调用处的函数名。一般在代码中用inline修饰,但是能否形成内联函数,需要看编译器对该函数定义的具体处理。带有参数的宏定义中不含有类型名称,多行语句一般使用do while语句,例如:
- 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宏定义的常见二义性
2.2宏定义的常见二义性
1)没有给参数加括号从而导致的优先级混乱
2)在传递参数的时候使用了表达式,表达式中含有++运算,从而导致的参数失真
3.二者的区别
内联函数和宏的区别在于,宏是由预处理器对宏进行替代,而内联函数是通过编译器控制来实现的。而且内联函数是真正的函数,只是在需要用到的时候,内联函数像宏一样的展开,所以取消了函数的参数压栈,减少了调用的开销。你可以象调用函数一样来调用内联函数,而不必担心会产生于处理宏的一些问题。