typedef

  • 用法一:可以减少代码的书写量

struct student{

int data;

char name[10];

};
当我们定义学生结构体的时候要这么定义struct student s1,s2,s3; 如果想定义结构体指针,我们可以这么定义,struct student *ps1, ps2; 显然ps2不是指针类型,但是好多初学者对指针不熟悉,所以容易出错,但是当我们用typedef的时候,就不会出现这样的错误了,

typedef struct student{

int data;

char name[10];

}stu, *pstu;
我们定义的时候可以这么定义stu s1, s2, s3; 定义结构体指针的时候,可以这么定义,pstu ps1, ps2; 这样ps1, ps2都是指针类型的变量 这是typedef的用法之一,也是比较常用的。

  • 用法二:可以实现代码的复用性和可扩展性

如果一段代码没有扩展性和复用性,那么这段代码就不能算得上是一段特别规范的代码,就像我们为了实现代码的复用性,提高程序可读性的时候,用函数一样,提高代码的复用性和可扩展性是作为软件开发者必备的本领。一段好的代码,如果在别的项目中引用的话,如果功能类似,基本上改不了几行,这就是规范性的重要性(这里先不谈规范性,但是这个typedef的用法也涉及规范性,嘿嘿,所以规范是避免不了的)。就这么来说吧,假如我们定义了一个结构体

struct student{

int score;

char name[10];

};我们想把成绩改成double类型的,应为int的精度太低了,但是下面用到的地方可能都要改掉,但是,我们要是用typedef一下, 问题就变得简单多了,

typedef int typeitem;

struct student{

typeitem score;

char name[10];

};这样直接改typedef就行了,其他的代码根本不用动,这就是分层的原因,我们只改变最底层的,上层的东西根本不用变(就像在链表中,我们可以把它分为三层,纯数据层、节点层、head指针层,也就是整条链)这样分层处理问题会变得简单得多。还有就是平台不同可以兼容,就像有的平台不支持long double类型,但是你如果定义了long double 直接不能用,但是如果这么 typedef long double typeitem; 直接改成可以支持的类型就行啦,根本不用那么麻烦改下面的代码,这也是比较重要的用途。

  • 用途三:简化,提高可读性

想必大家觉得,这个用途不是包含在上面的用途之中了吗,为什么还要再说一遍呢,其实我举个例子你也就明白了,typedef int array[10],这个代表什么意思,这可不是平时那种array[10】是个int了吧,这个代表,array是个重定义的类型,array a; 就代表a是一个含有10个int型元素的数组,这么定义可能觉得简化不了多少,还不如直接int a[10];看着明白呢,好! 继续往下看,typedef array Array[5]; 这个呢,如果我这么定义一个变量 Array arr[2]; 这个又是什么意思呢?这个就是定义个Array类型数组,其中这个“一维”数组有两个元素,但是每个元素又都是Array 类型的,每个Array又是一个5行10列二维数组,所以arr就是一个三维数组,他就等于int arr[2][5][10]; 是不是看的有点蒙了, 其实在C语言中根本不存在多维数组,全部都是一维数组,只是一维数组里面又含一维数组,所以才构成了所谓的“多维”数组, 如果这样理解的话,是不是觉得多维数组也就不那么“神奇”了,变得简单了,没有那么晕了,这样定义的好处就是可以讲一个多维的数组转化成我们比较熟悉的一维数组,这样操作起来就比较容易了,可读性自然也会增强。所以这就是他的“简化”的作用。其实我们还可以在函数指针上体现,想定义个函数指针int (p)(); 我们可以定义为typedef int (POWER)(); 接下来可以直接定义POWER p1, p2; 他就等价于int (p1)(), int (p2)(); 这样也非常易懂。

你可能感兴趣的:(typedef)