typedef 与 #define 的区别
(1)#define可以使用其他类型说明符对宏类型名进行扩展,但对 typedef 所定义的类型名却不能这样做。例如:
#define INTERGE int;
unsigned INTERGE n; //没问题
typedef int INTERGE;
unsigned INTERGE n; //错误,不能在 INTERGE 前面添加 unsigned
(2) 在连续定义几个变量的时候,typedef 能够保证定义的所有变量均为同一类型,而 #define 则无法保证。例如:
#define PTR_INT int *
PTR_INT p1, p2; //p1、p2 类型不相同,宏展开后变为int *p1, p2;
typedef int * PTR_INT
PTR_INT p1, p2; //p1、p2 类型相同,它们都是指向 int 类型的指针。
typedef 与 #define 比较
typdef 的一些特性与 define 的功能重合。例如:
#define BYTE unsigned char
这是预处理器用 BYTE 替换 unsigned char。
但也有 #define 没有的功能,例如:
typedef char * STRING;
编译器把 STRING 解释为一个类型的表示符,该类型指向 char。因此:
STRING name, sign;
相当于:
char * name , * sign;
但是,如果这样假设:
#define STRING char *
然后,下面的声明:
STRING name, sign;
将被翻译成:
char * name, sign;
这导致 name 才是指针。
简而言之,#define 只是字面上的替换,由预处理器执行,#define A B 相当于打开编辑器的替换功能,把所有的 B 替换成 A。
与 #define 不同,typedef 具有以下三个特点:
1.typedef 给出的符号名称仅限于对类型,而不是对值。
2.typedef 的解释由编译器,而不是预处理器执行。并不是简单的文本替换。
3.虽然范围有限,但是在其受限范围内 typedef 比 #define 灵活。
用 typedef 为数组去别名:
typedef int A[6];
表示用 A 代替 int [6]。
即:A a; 等于 int a[6];
typedef 还有一个作用,就是为复杂的声明定义一个新的简单的别名。用在回调函数中特别好用:
1. 原声明:int *(*a[5])(int, char*);
在这里,变量名为 a,直接用一个新别名 pFun 替换 a 就可以了:
typedef int *(*pFun)(int, char*);
于是,原声明的最简化版:
pFun a[5];
2. 原声明:void (*b[10]) (void (*)());
这里,变量名为 b,先替换右边部分括号里的,pFunParam 为别名一:
typedef void (*pFunParam)();
再替换左边的变量 b,pFunx 为别名二:
typedef void (*pFunx)(pFunParam);
于是,原声明的最简化版:
pFunx b[10];
其实,可以这样理解:
typedef int *(*pFun)(int, char*);
由 typedef 定义的函数 pFun,为一个新的类型,所以这个新的类型可以像 int 一样定义变量,于是,pFun a[5];就定义了 int *(*a[5])(int, char*);
所以我们可以用来定义回调函数,特别好用。
另外,也要注意,typedef 在语法上是一个存储类的关键字(如 auto、extern、mutable、static、register 等一样),虽然它并不真正影响对象的存储特性,如:
typedef static int INT2; // 不可行
编译将失败,会提示“指定了一个以上的存储类”。