新闻  |   论坛  |   博客  |   在线研讨会
typedef使用大全1(数组)
yanqin | 2009-04-16 16:45:01    阅读:1565   发布文章

typedef使用大全1(数组)
%A
%A typedef到处都是,但是能够真正懂得typedef使用的不算太多。对于初学者而言,看别人的源码时对到处充斥的typedef往往不知所错,而参考书又很少,所以在此给出一个源码,供大家参考
%A
%A #include <stdio.h>
%A #include <iostream.h>
%A
%A /* 避免Visual C的for与标准for的不同 */
%A #define for  if (0);   else for
%A
%A /* dim(a)是用于计算a的维数,不过只能计算数组的维数,不能计算指针的维数 */
%A #define dim(a) (sizeof(a)/sizeof(a[0]))
%A
%A /* N1到N4是几个常量,以枚举的形式定义 */
%A enum {N1 = 2, N2 = 3, N3 = 4, N4 = 5};
%A
%A /* 这个C程序员都知道,就是将DataType定义为int型,便于扩充 */
%A typedef int DataType;
%A
%A /* 定义一个一维数组,数组的元素为整型值 */
%A typedef DataType ARR1[N4];
%A
%A /* 再定义一个一维数组,数组的元素维ARR1型,不过ARR1又是一个数组,所以
%A * ARR2 实际上是一个矩阵
%A */
%A typedef ARR1 ARR2[N3]; /* 此处完全等价为typedef int ARR2[N3][N4];*/
%A
%A /* 按照ARR2的解释,ARR3也是一个一维数组,不过数组元素的类型是ARR2的类型
%A * 所有ARR3是一个三维数组
%A */
%A typedef ARR2 ARR3[N2]; /* 此处完全等价为typedef int ARR3[N2][N3][N4];*/
%A
%A /* 分别用定义好的ARR1,ARR2,ARR3定义三个变量a, b, c */
%A ARR1 a; /* 此处完全等价于:int a[N4]; */
%A ARR2 b; /* 此处完全等价于:int b[N3][N4]; */
%A ARR3 c; /* 此处完全等价于:int c[N2][N3][N4]; */
%A
%A /* 下面函数给大家个示例看a,b,c如何使用 */
%A void exam_1()
%A {
%A     for (int i=0; i<dim(a); i++) a[i] = i+1;
%A
%A     for (int i=0; i<dim(b); i++) for (int j=0; j<dim(b[0]); j++)
%A         b[i][j] = (i+1)*10 + (j+1);
%A
%A     for (int i=0; i<dim(c); i++) for (int j=0; j<dim(c[0]); j++)
%A         for (int k=0; k<dim(c[0][0]); k++) c[i][j][k] = (i+1)*100 + (j+1)*10 + (k+1);
%A
%A     printf("\nThe a is :\n");
%A     for (int i=0; i<dim(a); i++) printf("%4d ", a[i]);
%A     printf("\n");
%A
%A     printf("\nThe b is :\n");
%A     for (int i=0; i<dim(b); i++)
%A     {
%A         for (int j=0; j<dim(b[0]); j++) printf("%4d ", b[i][j]);
%A         printf("\n");
%A     }
%A
%A     printf("\nthe c is:\n");
%A     for (int i=0; i<dim(c); i++)
%A     {
%A         for (int j=0; j<dim(c[0]); j++)
%A         {
%A             for (int k=0; k<dim(c[0][0]); k++) printf("%4d ", c[i][j][k]);
%A             printf("\n");
%A         }
%A         printf("\n");
%A     }
%A }
%A
%A /* 下面函数给大家演示数组在内存中的排列 */
%A void exam_2()
%A {
%A     int *pn = NULL;
%A
%A     pn = (int *)a; /* 等价于 pn = &a[0]; */
%A     printf("\nThe a is :\n");
%A     for (int i=0; i<sizeof(a)/sizeof(DataType); i++) printf("%4d ", pn[i]);
%A     printf("\n");
%A
%A     pn = (int *)b; /* 等价于 pn = &b[0][0]; */
%A     printf("\nThe b is :\n");
%A     for (int i=0; i<sizeof(b)/sizeof(DataType); i++) printf("%4d ", pn[i]);
%A     printf("\n");
%A
%A     pn = (int *)c; /* 等价于 pn = &c[0][0][0]; */
%A     printf("\nThe c is :\n");
%A     for (int i=0; i<sizeof(c)/sizeof(DataType); i++) printf("%4d ", pn[i]);
%A     printf("\n");
%A }
%A
%A int main(int argc, char* argv[])
%A {
%A     exam_1();
%A     exam_2();
%A     return 0;
%A }
%A
%A
%A%A
%A

*博客内容为网友个人发布,仅代表博主个人观点,如有侵权请联系工作人员删除。

参与讨论
登录后参与讨论
推荐文章
最近访客