濉溪建设投资网站,舞台快速搭建,宜昌教育云网站建设,连云港网站建设方案用途一#xff1a;定义一种类型的别名#xff0c;而不只是简单的宏替换。可以用作同时声明指针型的多个对象。比如#xff1a;char* pa, pb; // 这多数不符合我们的意图#xff0c;它只声明了一个指向字符变量的指针#xff0c; // 和一个字符变量用途一定义一种类型的别名而不只是简单的宏替换。可以用作同时声明指针型的多个对象。比如char* pa, pb; // 这多数不符合我们的意图它只声明了一个指向字符变量的指针 // 和一个字符变量以下则可行typedef char* PCHAR; // 一般用大写PCHAR pa, pb; // 可行同时声明了两个指向字符变量的指针虽然char *pa, *pb;也可行但相对来说没有用typedef的形式直观尤其在需要大量指针的地方typedef的方式更省事。用途二用在旧的C的代码中具体多旧没有查帮助struct。以前的代码中声明struct新对象时必须要带上struct即形式为 struct 结构名 对象名如struct tagPOINT1{ int x; int y;};struct tagPOINT1 p1; 而在C中则可以直接写结构名 对象名即tagPOINT1 p1;估计某人觉得经常多写一个struct太麻烦了于是就发明了typedef struct tagPOINT{ int x; int y;}POINT;POINT p1; // 这样就比原来的方式少写了一个struct比较省事尤其在大量使用的时候或许在C中typedef的这种用途二不是很大但是理解了它对掌握以前的旧代码还是有帮助的毕竟我们在项目中有可能会遇到较早些年代遗留下来的代码。用途三用typedef来定义与平台无关的类型。比如定义一个叫 REAL 的浮点类型在目标平台一上让它表示最高精度的类型为typedef long double REAL; 在不支持 long double 的平台二上改为typedef double REAL; 在连 double 都不支持的平台三上改为typedef float REAL; 也就是说当跨平台时只要改下 typedef 本身就行不用对其他源码做任何修改。标准库就广泛使用了这个技巧比如size_t。另外因为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)();再替换左边的变量bpFunx为别名二typedef void (*pFunx)(pFunParam);原声明的最简化版pFunx b[10];3. 原声明doube(*)() (*e)[9]; 变量名为e先替换左边部分pFuny为别名一typedef double(*pFuny)();再替换右边的变量epFunParamy为别名二typedef pFuny (*pFunParamy)[9];原声明的最简化版pFunParamy e; 理解复杂声明可用的“右左法则”从变量名看起先往右再往左碰到一个圆括号就调转阅读的方向括号内分析完就跳出括号还是按先右后左的顺序如此循环直到整个声明分析完。举例int (*func)(int *p);首先找到变量名func外面有一对圆括号而且左边是一个*号这说明func是一个指针然后跳出这个圆括号先看右边又遇到圆括号这说明(*func)是一个函数所以func是一个指向这类函数的指针即函数指针这类函数具有int*类型的形参返回值类型是int。int (*func[5])(int *);func右边是一个[]运算符说明func是具有5个元素的数组func的左边有一个*说明func的元素是指针注意这里的*不是修饰func而是修饰func[5]的原因是[]运算符优先级比*高func先跟[]结合。跳出这个括号看右边又遇到圆括号说明func数组的元素是函数类型的指针它指向的函数具有int*类型的形参返回值类型为int。也可以记住2个模式type (*)(....)函数指针 type (*)[]数组指针 陷阱一记住typedef是定义了一种类型的新别名不同于宏它不是简单的字符串替换。比如先定义typedef char* PSTR;然后int mystrcmp(const PSTR, const PSTR);const PSTR实际上相当于const char*吗不是的它实际上相当于char* const。原因在于const给予了整个指针本身以常量性也就是形成了常量指针char* const。简单来说记住当const和typedef一起出现时typedef不会是简单的字符串替换就行。陷阱二typedef在语法上是一个存储类的关键字如auto、extern、mutable、static、register等一样虽然它并不真正影响对象的存储特性如typedef static int INT2; //不可行编译将失败会提示“指定了一个以上的存储类”。转载于:https://www.cnblogs.com/rogee/archive/2010/10/12/1848818.html