typedef的真正含意[转自csdn]

typedef的真正含意

1. 找到你所要申明的通用格式。例如这里申明int a[4], b[4], c[4];只有a,b,c不同,它们有相同的申明模式 int <名字>[4];

2.
用你想申明的新类型名代替通用格式中的变化部分。例如这里就是用新类型int_array代替a,b,c所在的位置,再在前面加上typedef符号,即:

typedef int int_array[4];

3.
以后你想申明处在上面int_array位置的a,b,c类型时,就可以用如下语句:

int_array a, b, c;
简单点说在一个定义 typedef <字符串>;中, <字符串>中会出现一个未定义的类型名Type_A, 当你使用该typedef的时候:

Type_A object;
它的含义就是:你实际上申明的是用object名去替换<字符串>中的 Type_A
例如 typedef int int_array[4];

int_array object;
实际上你写的申明是:用object替换字符串” int int_array[4];”中的 int_array得到的结果: int object[4];
这也就是编译器处理tyepdef定义的原理。
定义类型只用写出一个完整的定义..前边上typedef 就行了.


char *cstr;//
定义了一个char*变量cstr.

typedef char *cstr;//
char*起个别名cstr;



int int_array[10];//
定义一个数组int_array.

typedef int int_array[10]//int_array
变成了int[10]的别名.


void (*pfn)(void);//
定义了一个函数指针.

typedef void (*pfn)(void);//
为此函数指针起了个别名.


typedef int (*pf)();

pf test[10];

这样定义就是把pf作为一个类型,是一个int型的函数指针类型。
所以,pf test[10];//这样就是定义了函数指针的数组,数组含10个元素。
总结:typedef的作用是将一个变量变为它本身的类型,而不是为一个类型定义一个别名。
typedef使用大全1(数组)

typedef到处都是,但是能够真正懂得typedef使用的不算太多。对于初学者而言,看别人的源码时对到处充斥的typedef往往不知所错,而参考书又很少,所以在此给出一个源码,供大家参考

#include <stdio.h>
#include <iostream.h>
/* 避免Visual Cfor与标准for的不同 */
#definefor if (0);   elsefor
/* dim(a)是用于计算a的维数,不过只能计算数组的维数,不能计算指针的维数 */
#define dim(a) (sizeof(a)/sizeof(a[0]))
/* N1N4是几个常量,以枚举的形式定义 */
enum {N1 = 2, N2 = 3, N3 = 4, N4 = 5};
/* 这个C程序员都知道,就是将DataType定义为int型,便于扩充 */
typedefint DataType;
/* 定义一个一维数组,数组的元素维整型值 */
typedef DataType ARR1[N4];
/* 再定义一个一维数组,数组的元素维ARR1型,不过ARR1又是一个数组,所以
* ARR2 实际上是一个矩阵
*/
typedef ARR1 ARR2[N3]; /* 此处完全等价为typedef int ARR2[N3][N4];*/
/* 按照ARR2的解释,ARR3也是一个一维数组,不过数组元素的类型是ARR2的类型
* 所有ARR3是一个三维数组
*/
typedef ARR2 ARR3[N2]; /* 此处完全等价为typedef int ARR3[N2][N3][N4];*/
/* 分别用定义好的ARR1ARR2ARR3定义三个变量a, b, c */
ARR1 a; /* 此处完全等价于:int a[N4]; */
ARR2 b; /* 此处完全等价于:int b[N3][N4]; */
ARR3 c; /* 此处完全等价于:int c[N2][N3][N4]; */
/* 下面函数给大家个示例看a,b,c如何使用 */
void exam_1()
{
    for (int i=0; i<dim(a); i++) a[i] = i+1;
    for (int i=0; i<dim(b); i++) for (int j=0; j<dim(b[0]); j++)
        b[i][j] = (i+1)*10 + (j+1);
    for (int i=0; i<dim(c); i++) for (int j=0; j<dim(c[0]); j++)
        for (int k=0; k<dim(c[0][0]); k++) c[i][j][k] = (i+1)*100 + (j+1)*10 + (k+1);
    printf(“nThe a is :n”);
    for (int i=0; i<dim(a); i++) printf(“%4d “, a[i]);
    printf(“n”);
    printf(“nThe b is :n”);
    for (int i=0; i<dim(b); i++)
    {
        for (int j=0; j<dim(b[0]); j++) printf(“%4d “, b[i][j]);
        printf(“n”);
    }
    printf(“nthe c is:n”);
    for (int i=0; i<dim(c); i++)
    {
        for (int j=0; j<dim(c[0]); j++)
        {
            for (int k=0; k<dim(c[0][0]); k++) printf(“%4d “, c[i][j][k]);
            printf(“n”);
        }
        printf(“n”);
    }
}
/* 下面函数给大家演示数组在内存中的排列 */
void exam_2()
{
    int *pn = NULL;
    pn = (int *)a; /* 等价于 pn = &a[0]; */
    printf(“nThe a is :n”);
    for (int i=0; i<sizeof(a)/sizeof(DataType); i++) printf(“%4d “, pn[i]);
    printf(“n”);
    pn = (int *)b; /* 等价于 pn = &b[0][0]; */
    printf(“nThe b is :n”);
    for (int i=0; i<sizeof(b)/sizeof(DataType); i++) printf(“%4d “, pn[i]);
    printf(“n”);
    pn = (int *)c; /* 等价于 pn = &c[0][0][0]; */
    printf(“nThe c is :n”);
    for (int i=0; i<sizeof(c)/sizeof(DataType); i++) printf(“%4d “, pn[i]);
    printf(“n”);
}
int main(int argc, char* argv[])
{
    exam_1();
    exam_2();
    return 0;
}