typedef定义数组
typedef定义数组
问题来源
在学习高一凡数据结构与算法解析串这一章节时,遇到如下代码不明白其意义,经过查阅终于搞明白
typedef unsigned char SString[MAXLEN + 1];
使用typedef语句定义数组类型
一维数组类型的定义格式
格式:typedef<元素类型关键字><数组类型名>[常量表达式]
例如:
typedef int vector[10];
typedef char strings[80];
typedef short array[N];
-
第一条语句定义了一个元素类型为int,含有10个元素的数组类型vector,若不使用typedef保留字,则就变成了数组定义,它只定义了一个元素类型为int,含有10个元素的数组vector。这两种定义有着本质的区别,若定义的是数组vector,系统将为它分配有保存10个整数的存储单元,共40个字节的存储空间;若定义的是数组类型vector,系统只是把该类型的有关信息登记下来,待以后利用该类型定义对象时使用,具体地说,就是把vector的元素类型int,类型长度10,类型名vector等登记下来,待以后定义vector类型的对象时使用。
-
第二条语句定义了一个元素类型为插入,含有80个元素的数组类型strings,以后可以直接用strings类型定义数组对象,每个数组对象的元素为char型,数组长度(即元素个数)为80。
-
第三条语句定义了一个元素类型为short int的含有N个元素(N为已定义的符号常量)的数组类型array,以后利用它可以直接定义该类型的对象,它是一个含有N个短整型元素的数组。
利用上面的定义可以定义如下的几个对象:
vector v1,v2;
strings s1,s2;
array a;
typedef vector vectorSet[20];
vectorSet vs;
-
第一条语句定义了一个元素类型为vector,元素个数为20的数组类型vectorSet
-
第二条语句定义了数据类型为vectorSet的一个对象vs,该对象包含有20个类型为vector的元素,每个元素又包含有10个int类型的元素,所以整个数组共包含有20行10列共200个整数元素,等同于对vs的如下定义
int vs[20][10];
二维数组类型的定义格式
格式:typedef<元素类型关键字><数组类型名>[<常量表达式1>][<常量表达式2>]
例如:
typedef int matrix[5][5];
typedef char nameTable[10][NN];
typedef double DD[M+1][N+1];
-
第一条语句定义了含有5行5列共25个int型元素的数组类型matrix
-
第二条语句定义了10行NN列共10*NN个char类型元素的数组类型nameTable
-
第三条语句定义了含有M+1行N+1列共(M+1)*(N+1)个double类型元素的数组类型DD
利用上面三个二维数组类型可以直接定义出相应的二维数组。例如:
matrix mx;
nameTable nt;
DD dd;
对已有类型定义别名
利用typedef语句不仅能够定义数组类型,而且能够对已有类型定义出另一个类型名,以此作为原类型的一个别名。如下:
typedef int inData;
typedef char chData;
typedef char* chPointer;
-
第一条语句对int类型定义了一个别名inData
-
第二条语句对char类型定义了一个别名chData
-
第三条语句对char*类型定义了一个别名chPointer
通过上面的重命名,后面可以直接使用inData,chData和chPointer定义出相应的对象。例如:
inData x,y;
inData a[5] = {1,2,3,4,5};
chData b1,b2 = 'a';
chData c[10] = "char data";
chPointer p = NULL;
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/smilesundream/article/details/70161471