二维数组本质还是一维数组,数组中的每一个元素都是数组,这些元素具有相同的属性。既然是数组类型,其具备两个条件:1.数组元素的个数;2.数组元素的类型 验证二维数组本质是一维数组:
void show(int* a,int n){
for(int i=0;i < n;++i){
printf("%d ",a[i]);
}
}
int main(){
int A[] = {{1,2,3,4},{5,6,7,8},{9,10,11,12}};
int len = sizeof(A)/sizeof(A[0][0]);
show((int*)A,len);
return 0;
}
在内存中,是没有二维数组的。二维数组也是连续存放的,只是在逻辑上的二维。 验证二维数组的步长:
test.c
int A[][4] = {{1,2,3,4},{5,6,7,8},{9,10,11,12}};
printf("A:%d , A+1:%d",A,A+1);
//验证每一个元素的步长,即一维数组的长度
printf("&A:%d , &A+1:%d",&A,&A+1);
//验证整个二维数组的步长
二维数组名:二维数组名代表第0行首元素的地址,类同于 一维数组名代表首元素的地址。二维数组首元素就是首行,这个关系是一致的。
int A[][4] = {{1,2,3,4},{5,6,7,8},{9,10,11,12}};
//A: 代表第0行首地址
//A+i<=>&A[i]: 代表第i行首地址
//*(A+i)<=>A[i]: 代表第i行首元素的地址
//*(A+i)+j<=>&A[i][j]: 代表第i行第j列元素的地址
//*(*(A+i)+j)<=>A[i][j]: 代表第i行第j列元素的值
指向二维数组的数组指针
int A[][4] = {{1,2,3,4},{5,6,7,8},{9,10,11,12}};
int (*p)[4] = A;
//注意不能写为int (*p)[4] = &A;
//&A是指整个二维数组的首地址
//int (*p)[4];p指向元素类型为int,元素个数为4的一维数组
int (*q)[][4] = A;
二维数组做形式参数
//数组做参数时会退化指针,不同是指针的步长不相同
void show(int (*A)[4]){
for(int i=0;i<3;++i){
for(int j=0;j<4;++j){
printf("%d ",A[i][j]);
}
printf("\n");
}
printf("\n");
}
int main(){
int A[][4] = {{1,2,3,4},{5,6,7,8},{9,10,11,12}};
show(A);
return 0;
}