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不是简单替换 ,而是采用如同定义变量的方法那样来声明一种类型。也就是说;
//refer to (xzgyb(老达摩))
#define int_ptr int *
int_ptr a, b; //相当于int * a, b; 只是简单的宏替换
typedef int* int_ptr;
int_ptr a, b; //a, b 都为指向int的指针,typedef为int* 引入了一个新的助记符
这也说明了为什么下面观点成立
//QunKangLi(维护成本与程序员的创造力的平方成正比)
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 不是语句 不要在行末加分号,否则 会连分号一块置换。
而关于 上面pint 指针锁定,p不可修改。 PINT 是锁定指针p所指的对象。可以用下面的例子:
首先说一下const
const在声明变量时,说明该变量的值在其生存周期里是不可以改变的。
对一般的变量而言。const的位置不同表达的意思是一样的,如:
int const a;
const int a;
这俩者是一样的,凭你喜好来选择。
但对于指针中却不一样,位置不同所表达的含义却不一样。如:
int const * pci;
//指向(整形常量)的指针。指针(pci)可改变,指针指向的值(&pci)不能改变
int *const cpi;
//指向整形的(常量指针)。指针(cpi)不能变,指针指向的值(&cpi)可以改变
int const * const cpci;
//指向(整形常量)的(常量指针)。指针和指针指向的值都不能改变
#include <stdio.h> int main() { int a = 1 ,b =2, c = 3; int const *pci = &a; //指向(整形常量)的指针。指针(pci)可改变,指针指向的值(&pci)不能改变 int *const cpi = &b; //指向整形的(常量指针)。指针(cpi)不能变,指针指向的值(&cpi)可以改变 int const * const cpci = &c;//指向(整形常量)的(常量指针)。二者都不能变 printf("原始赋值后(地址):pci=%5x *cpi = %5x *cpci = %5x\n",pci,cpi,cpci); printf("原始赋值后(数值):*pci=%d *cpi = %d *cpci = %d\n",*pci,*cpi,*cpci); pci = &b; //正确。pci的指针可以改变 地址改变到了b //*pci = 8; //出错。pci的指针指向的变量的值不能改变 //cpi = &c; //出错。cpi的指针的不能改变 *cpi = 8; //正确。cpi的指针指向的变量的值不能改变 这里将b的值改成了8 //cpci = &a; //出错。cpci的指针的不能改变 //*cpci = 8; //出错。cpci指针指向的变量的值不能改变 printf("改变赋值后(地址):pci=%5x *cpi = %5x *cpci = %5x\n",pci,cpi,cpci); printf("改变赋值后(数值):*pci=%d *cpi = %d *cpci = %d\n",*pci,*cpi,*cpci); return 0; }