首先看段代码:
int b = 12;
int *p = &b; //指针变量p指向变量b
printf("%p\n",p);//指针p保存的b的地址 printf("%p\n",&p);//指针变量b本身的地址
char a ='b';
printf("%p\n",&a);
int *p2 =&a; //int类型指针变量p2 指向char变量a
*p2=20;
printf("%p\n",p);
打印结果:
0x7fff5fbff744 //前:指针p保存的地址
0x7fff5fbff738 0x7fff5fbff7370x7fff5f000000 //后:指针p保存的地址
先定义的变量b地址最大,次定义的指针变量p次之,最后定义的变量a最小
char类型变量a只占一个字节,指针类型p是跟a连续的内存空间,占8个字节
而通过p2改变a的值的时候,因为p2是int形指针,p2指向char类型的a,并更改了其保存的值,那么
p2指向的地址虽然依然是0xfff5fbff737,但是因为p2指针是4个字节的,
所以这个更改的值20,它会把紧靠着0xfff5fbff737的内存0xfff5fbff738,0xfff5fbff739,0xfff5fbff740都置为0
而地址为0xfff5fbff738,0xfff5fbff739,0xfff5fbff740的内存空间却刚好是指针变量p的内存中的一部分,
根据十六进制转换二进制的规则每4位二进制对应一个十六进制。所以地址为38,39,40的三字节二进制对刚好对应6个0
所以打印的p的地址前后不一样
什么类型的指针变量就保存什么类型的变量的地址。