数组指针的概念一直就没理解太清楚,中间有很多次,以为清楚了,但是还没有真正的了解清楚。要洞察这里面的问题,就首先要了解编译器在这里面做了什么。
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],所以上面三个地址都是相同的。