解答:#define MIN(A,B) ((A) <= (B) ? (A) : (B)) MIN(*p++, b)会产生宏副作用
剖析:这个面试题主要考察宏定义可以实现函数的功能。但是它终归不是函数,宏定义中括弧的”参数“也不是真的参数,在宏展开的时候对”参数“进行的是一对一的替换。
C++中另一个进行代码替换的是#inline,它们之间的区别是:
1. define只是简单的宏替换,通常会产生二义性;而inline会真正地编译到代码中
2. inline函数是否展开由编译器决定,有时候当函数太大时,编译器可能选择不展开相应的函数
程序员对宏定义的使用要非常小心,特别注意以下两个问题:
(1)谨慎地将宏定义中的“参数”和整个宏虹括号括起来。所以严格地将讲,下述解答#define MIN(A,B) (A) <= (B) ? (A) : (B) 以及 #define MIN(A,B) (A <= B ? A : B) 都是不对的。
(2)防止宏的副作用。宏定义#define MIN(A,B) ((A) <= (B) ? (A) : (B)) 对MIN(*p++, b)的作用结果是 ((*p++) <= (b) ? (*p++) : (*p++))这个表示式会产生副作用,指针p会作三次++自增操作
除此之外,另一个不好的解答是#define MIN(A,B) ((A) <= (B) ? (A) : (B));
这个解答在宏定义的后面加了“;“