陷阱一: 记住,typedef是定义了一种类型的新别名,不同于宏,它不是简单的字符串替换。比如:
2 U) c2 { K- q' O/ L) u( x 先定义:& j+ c, ^/ b9 I$ J5 J
typedef char* PSTR;
; r" t5 F& {" h' @- A Q) s& u7 ? 然后:, X0 s: g0 P" j8 N( _- d7 ^) [4 u
int mystrcmp(const PSTR, const PSTR);
: a% O# O4 e/ |: x- p" ] const PSTR实际上相当于const char*吗?不是的,它实际上相当于char* const。# a) z! l1 f1 |" j
原因在于const给予了整个指针本身以常量性,也就是形成了常量指针char* const。
+ }/ G8 Q: O3 x* O3 C, Z5 V 简单来说,记住当const和typedef一起出现时,typedef不会是简单的字符串替换就行。8 [2 H; V" S- V( ^" R+ Z5 @4 p% _
陷阱二:4 Y8 p) B6 d" j- K3 P a# \/ A* c
typedef在语法上是一个存储类的关键字(如auto、extern、mutable、static、register等一样),虽然它并不真正影响对象的存储特性,如:1 {* Q& t0 M% k# B3 x/ i- t
typedef static int INT2; //不可行
' E7 d+ [1 F6 B D# ^ 编译将失败,会提示“指定了一个以上的存储类”。 |