多维数组的本质
#include<stdio.h> #include<string.h> int main() { int a[3][5]; int i,j; int temp = 0; for(i = 0; i < 3; i++) { for(j = 0; j < 5; j++) { a[i][j] = temp++; } } for(i = 0; i < 3; i++) { for(j = 0; j < 5; j++) { printf("a[i][j] = %d\n",a[i][j]); } } printf("a : %d, a + 1 : %d\n",a,a+1); printf("&a : %d, &(a + 1) : %d\n",a,a+1); return 0; }
运行结果:
二维数组指针的步长是20(5*4:5个int型数据*4bit)
#include<stdio.h> #include<string.h> int main() { int a[3][5]; int i,j; int temp = 0; for(i = 0; i < 3; i++) { for(j = 0; j < 5; j++) { a[i][j] = temp++; } } for(i = 0; i < 3; i++) { for(j = 0; j < 5; j++) { printf("a[i][j] = %d\n",a[i][j]); } } { int (*pArray)[5]; pArray = a; for(i = 0; i < 3; i++) { for(j = 0; j < 5; j++) { printf("pArray[i][j] = %d\n",pArray[i][j]); } } } printf("a : %d, a + 1 : %d\n",a,a+1); printf("&a : %d, &(a + 1) : %d\n",a,a+1); return 0; }
编译通过,运行成功。
多维数组名的本质就是数组指针 ==》步长、一维长度。
(a+i) 代表第i行的首地址
*(a+i) 代表一级指针,第i行首元素地址
*(a+i)+j 代表a[i][j]元素
第一行的地址和第一行的首元素地址是重叠的
*(a+i)+j == a[i][j]