关于二维数组做函数参数,传递形参的形式的问题

来源:互联网 发布:淘宝一口价修改不降权 编辑:程序博客网 时间:2024/06/06 17:08
数组作为参数进行传递,不能将数组的所用元素一次全都传进子函数中,
要么我们可以一次传进去数组中一个元素的内容,要么我们可以传一个数
组的指针,传递一维数组的指针这里不讲,只说一下传递二维数组时,二
维数组做形参的形式。
我目前知道的有三种形式:
1. void func(int matrix[][4]); //传递一个二维数组,其中第二维的大小
//不能省略,这里以4举例。
2. void func(int (*p)[4]); // 这里定义一个指针p,这个指针p指向的是
//一个数组,这个数组的长度是4,也可以这么理解,p指向的是二维数组中
//的每一行
3. void func(int **p);  //定义一个指针的指针,使用这种形式时要注意
//一些问题,就是在计算每行元素的首地址时,以及具体某个元素位置的
//地址时,需要进行强制类型转换才行。

上面这三种形式的形参都代表的是二维数组的指针。

函数中的形参其实相当于一个声明,并不产生内存分配,形参的目的就是
要让编译器知道函数参数的数据类型

如果第二维是固定的,可以用char (*p)[4] 这样的方式,
也可以用二级指针**p,同时要用参数传递数组的行和列的大小
大小,这时如果要表示其中的一个元素时,不能使用p[i][j]
这样的形式,必须自行计算出其偏移位置,同时在参数传递和使用
上要注意进行强制类型转换(参见后面程序)

另外一种形式为 void func(int[M][N] arrary_2d);
那么如果这样写void func(const int m,const int n,int array[m][n]) 对吗?
不对。 原因:数组的索引必须是个常量表达式,如果上面的const int m没有
初始化,那么系统将m或者n自动初始化为0,就产生了错误。

#include
void func(int **a)
{
int i,j;
for(i=0;i<3;i++)
for(j=0;j<2;j++)
printf("%d\n",*((int *)a+i*2+j));//在使用时用(int *) 来强转a
}
int main()
{
int i,j,sav[3][2]={{1,2},{3,4},{5,6}};
func((int **)sav); //在调用时需要用(int **)进行强转
return 0;
}


另外,下面是一种易和数组指针混淆的。

char *p[4]; 是一个指针数组,即数组中的内容是指针
这个指针数组可以这样用:
char *p[4];
char str[4][6];
for(int i=0;i<4;i++)
p[i]=str[i];
0 0