假设存在下面一个数组,要求用函数访问该数组
int a[2][3]=
{
{1,2,3},
{4,5,6},
};
1.
void show_array(int *a,int M,int N)
{
inti,j;
for(i=0;i
{
for(j=0;j
{
printf("%d ",*(a+i*N+j));
}
printf("\n");
}
}
二维数组里面的某一行的第一个元素的地址也代表了本行的地址,具有双重身份
二维数组名也是一个地址,就是a=a[0]=&a[0][0]
二维数组作为形式参数,a是一个一阶指针,用来存储普通变量的地址
这个函数是通过a,数组第一个元素的地址,然后自己计算行列来遍历访问二维数组。
show_array(a,3,3);//vs2012不可行
show_array(a[0],3,3);
show_array((int*)a,3,3);//强制类型转化二阶转化一阶
show_array(*a,3,3);//*a表示a[0];
下面的不对,本来以为二维数组就应该和二阶指针对应,后来发现不是。
二阶指针存储的必须是一个指针变量的地址。但是a[0]是一个地址常量,
表示的是数组第一行的地址,只是在数值上满足*a=&a[0][0]=a[0];
所以下面错了。在main函数中直接传递show(a,3,3)类型根本就不符合
void show_array(int **a,int M,int N)
{
inti,j;
for(i=0;i
{
for(j=0;j
{
printf("%d ",*(*(a+i)+j));
}
printf("\n");
}
}
在二维数组做形式参数的时候第二维不可省略,这里传递了一个指针数组,来存储每一行
的行首地址。所以正确,传递时候的参数是show_array2(a,3);
void show_array2(int (*a)[3],int M)
{
inti,j;
for(i=0;i
{
for(j=0;j<3;j++)
{
//printf("%d ",a[i][j]);
printf("%d ",*(a[i]+j));
}
printf("\n");
}
}
如果一定要用二阶指针访问二维数组,需要先用一阶指针数组先存储每一行的首地址,然后在用二阶指针存储一阶指针的地址,这是在主函数里面实现的。
int *p[2] = {a[0], a[1]};
int **pp = p;
然后就可以利用二阶指针pp进行访问了。