宏和内联
(1)在C 程序中,可以用宏代码提高执行效率。宏代码本身不是函数,但使用起来象函
数。预处理器用复制宏代码的方式代替函数调用,省去了参数压栈、生成汇编语言的CALL
调用、返回参数、执行return 等过程,从而提高了速度。使用宏代码最大的缺点是容易
出错,预处理器在复制宏代码时常常产生意想不到的边际效应。
(2)对于C++ 而言,使用宏代码还有另一种缺点:无法操作类的私有数据成员。
(3)C++ 的“函数内联”是如何工作的。对于任何内联函数,编译器在符号表里放入函数的声明(包括名字、参数类型、返回值类型)。如果编译器没有发现内联函数存在错误,那么该函数的代码也被放入符号表里。在调用一个内联函数时,编译器首先检查调用是否正确(进行类型安全检查,或者进行自动类型转换,当然对所有的函数都一样)。如果正确,内联函数的代码就会直接替换函数调用,于是省去了函数调用的开销。这个过程与预处理有显著的不同,因为预处理器不能进行类型安全检查,或者进行自动类型转换。假如内联函数是成员函数,对象的地址(this)会被放在合适的地方,这也是预处理器办不到的。
(4)C++ 语言的函数内联机制既具备宏代码的效率,又增加了安全性,而且可以自由操
作类的数据成员。