二维数组在内存中的存放方式和一维数组完全相同
下表把二维数组抽象成了行列形式方便理解
a[0]指向第一行首元素地址
a指向第一行的首地址
所以a地址和a[0]地址相同,因为起点相同
但a[0]+1往右偏移
但a+1往下方向偏移
方便理解
a+n控制行
a[0]+n控制列(相当于*a+n)
数组指针指向二维数组
int a[2][2] = {1, 2, 3, 4};
int main()
{int(*p)[2] = a;cout << p[0][0] << endl;p = new int[2][2];cout << p[0][0] << endl;}
数组指针指向动态分配的二维数组
int a[2][2] = {1, 2, 3, 4};
int main()
{int(*p)[2] = a;cout << p[0][0] << endl;p = new int[2][2];cout << p[0][0] << endl;}