关于typedef和define的区别以及用法

两者的区别:

1) #define是预处理指令,在编译预处理时进行简单的替换,不作正确性检查,不关含义是否正确照样带入,只有在编译已被展开的源程序时才会发现可能的错误并报错。例如:
#define PI 3.1415926
程序中的:area=PI*r*r 会替换为3.1415926*r*r
如果你把#define语句中的数字9 写成字母g 预处理也照样带入。

2)typedef是在编译时处理的。它在自己的作用域内给一个已经存在的类型一个别名,但是You cannot use the typedef specifier inside a function definition。

3)typedef int * int_ptr; 与 #define int_ptr int * 作用都是用int_ptr代表 int * ,但是二者不同,正如前面所说 ,#define在预处理 时进行简单的替换,而typedef不是简单替换 ,而是采用如同定义变量的方法那样来声明一种类型。也就是说;

#define int_ptr int *
int_ptr a, b; //相当于int * a, b; 只是简单的宏替换

typedef int* int_ptr;
int_ptr a, b; //a, b 都为指向int的指针,typedef为int* 引入了一个新的助记符

这也说明了为什么下面观点成立
typedef int * pint ;
#define PINT int *

那么:
const pint p ;//p不可更改,但p指向的内容可更改
const PINT p ;//p可更改,但是p指向的内容不可更改。

pint是一种指针类型 const pint p 就是把指针给锁住了 p不可更改
而const PINT p 是const int * p 锁的是指针p所指的对象。

3)#define 不是语句 不要在行末加分号,否则 会连分号一块置换。

typedef的用法:

#include <stdio.h><?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

#include <iostream.h>

 

/* 避免Visual Cfor与标准for的不同 */

#define for  if (0);   else for

 

/* dim(a)是用于计算a的维数,不过只能计算数组的维数,不能计算指针的维数 */

#define dim(a) (sizeof(a)/sizeof(a[0]))

 

/* N1N4是几个常量,以枚举的形式定义 */

enum {N1 = 2, N2 = 3, N3 = 4, N4 = 5};

 

/* 这个C程序员都知道,就是将DataType定义为int型,便于扩充 */

typedef int 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;

}

猜你喜欢

转载自blog.csdn.net/luckywizard/article/details/3137949