如果引入一个新类型的变量(例如p),使p等于变量的地址,*p代表变量的值,即对于上面的例子,只要使“p=&a”就使p存储了变量a的地址&a,而“*p”就是a的值,这就大大简化了表达式。通过声明一个指针变量,就可以实现这种操作。
int a=25;int *p;p=&a;
虽然p是指针变量,但这个变量与基本变量不一样。基本变量与基本数据类型相对应,如int变量存储整型值,char变量存储字符值,等等。但指针变量p存储的是地址值,所以
printf("%p/n",p);
语句输出的是存储变量x的地址,它和语句
printf("%d",&x);
是等效的,都是输出十六进制地址值“0012FF7C”(其实,这个值取决于机器)。而且不管是何种类型的指针,编译器都给它分配4个字节。
既然p具体存放的地址是内存里存放变量a的地址,*p就是这个地址所保存的值,也就是变量a的值。所以语句
printf("%d",a);
输出变量a的值25,它的等效语句是
printf("%d/n",*p);
下面是一个完整的演示程序。对比它们的输出,就会明白其中的奥妙。
【例2.16】演示输出指针的例子。
#include <stdio.h>void main ( ){ int a=25,*p; p=&a; printf("%d,0x%p/n", a, &a); printf("%d,0x%p/n", *p, p);}
使用“0x”标识地址是十六进制,程序输出如下。
25,0x0012FF7C25,0x0012FF7C