数组指针的概念一直就没理解太清楚,中间有很多次,以为清楚了,但是还没有真正的了解清楚。要洞察这里面的问题,就首先要了解编译器在这里面做了什么。
char A[][6]={"hello","world"};
这里声明并定义了一个二维数组,编译器采用直接赋值的方式给一块连续内存赋值。
char(*B)[6]=A;
这里声明并定义了一个数组指针,指向二维数组。数组指针和普通指针如何区别呢?在内存里面其实他们都是一个变量,存储的都是一个地址,地址保存的都是“普通变量”的值。因此他们并没有多少区别。关键的区别就在于程序语言中,数组指针可以“两次解引用”——比如**B(这一点类似于二级指针,注意区别),普通指针只可以“一次解引用”。
那么*B代表的意思和**B代表的意思有什么不同呢。
*B代表的是一维数组。**B代表的是一维数组中的元素。
int addressA=(int)A;
int addressP=(int)B; //&A[0]
int addressPX=(int)(*B); //&A[0][0]
因为A=&A[0]=&A[0][0],所以上面三个地址都是相同的。
本文详细解析数组指针的概念及其与编译器之间的互动过程,通过实例展示了数组指针与普通指针的区别,并阐述了两者在内存操作上的特性。深入探讨了数组指针的两次解引用与普通指针的一次解引用的区别,同时通过实例演示了如何通过指针获取数组元素的地址。

被折叠的 条评论
为什么被折叠?



