首先,原理为一维数组的数组名表示数组首元素的地址
看以下代码:
#include<stdio.h>
//void Show(int **brr)//error,如果传的是二维数组,则该方法是错误的,说明二维数组名并不是二级指针
//void Show(int brr[3][4])//这样的话对二维数组过于限制,将行列都给出,不便于代码的重用,不好
void Show(int (*brr)[4])//数组指针,用括号将*也括入,*brr==arr,将二维数组当作一维数组看,所以把*brr括入。右边带上列的数量。
{
for(int i=0;i<3;i++)
{
for(int j=0;j<4;j++)
{
printf("%d",brr[i][j]);
}
printf("\n");
}
}
//二维数组初始化的不同方式
int main()
{
int a = 10;
int arr[4] = {1,2,3,4};
int brr[3][4];
int crr[3][4] = {{1,2,3,4},{5,6,7,8},{9,10,11,12}};
int drr[3][4] = {1,2,3,4,5,6,7,8,9};//行优先
int err[][4] = {1,2,3,4,5,6};
brr[2][1] = 1;
Show(crr);//
return 0;
}
其中,Show()函数中的数组指针引用方式说明brr指针是一个指向4个单元的一维数组的指针,类型为int。