观点是:数组在使用过程中,会退化为指针。
*(array+1)+1相当于第一行第一列的元素地址,
一维数组,如果仅打印数组名,我们得到的是其首元素地址,二维数组也是如此。
直接推演二维数组。
二维数组名就相当于二维指针。
typedef int (*myint)[3];
int array[2][3] = { { 1, 2, 3 }, { 4, 5, 6 } };
myint p = array;
cout << p <<
endl<<array<<endl;//这里便是二维数组首元素地址,也是首行首元素地址。
cout << *(array + 1) << endl << *(p + 1)
<< endl;//数组第一行第0列地址
cout << **(array + 1)<< endl << **(p + 1)
<< endl;//数组第一行第0列元素值
cout << *(*(array + 1) + 1) << endl << *(*(p
+ 1) + 1) << endl;//数组第一行第1列元素值
每一行的结果都是一样的。
array本身就代表整个数组的地址,
*array就相当于开一层们,变成第一行首元素的地址,
当
array+1时,它会跳一行,变成第1行的首地址,然后*相当于一把钥匙,开一层们,*(array+1)便是第一行首元素地址。
然后*( *(array+1)+1),再打开一次们,就得到其元素值。