首先看一段代码:
#include<stdio.h>
int array[2][1] = {3,2};
int main()
{
int **a = (int **)&array[0][0];
int *b = &array[0][0];
printf("&a = %X-----&b = %X\n",&a,&b);
printf("&array[0][0] = %X\n",&array[0][0]);
printf("a = %X------b = %X\n",a,b);
return 0;
}
运行结果如下:
从上面的程序我们看出这几点:
- 指针也是有内存空间的,从它们有自己的内存地址可以看出
不管这个变量是几层指针,输出变量名就是输出该变量中存放的内容。上述程序中,输出变量名就是输出存放的array数组第一个变量的地址。
再看这样一段程序:
#include<stdio.h>
int array[2][1] = {3,2};
int main()
{
int **a = (int **)&array[0][0];
int *b = &array[0][0];
printf("*a = %d, *b = %d\n",*a,*b);
*a = b;
printf("a = %X,*a = %X,**a = %d\n",a,*a,**a);
printf("b = %X,*b = %d\n",b,*b);
printf("array[0][0] = %d\n",array[0][0]);
return 0;
}
运行结果如下:
从这里可以看出:对于指针变量来说,变量里存放的是某一个变量的地址值。加上*
号,就是寻找该地址对应的内存空间中存放的值。如果是多重指针变量的话,在前一次基础上再加上*
号就是以上次求得的值为地址,求取该地址对应的内存空间中存放的值。当然如果该地址不是在数据段的话,进行访问就会出现死机或者Segmentation fault。
对于上述*a = b;
操作后出现的数组第一个值被改变的原因是:b和a中存放的都是数组的首地址,而对该地址取值就是array的第一个值就是3.因此经过上面的操作后,3就被改变为0X403004了,转换为十进制数就是4206596了,也就是地址为0X403004的内存空间中存放的值为0X403004了。