1.二维数组如何作为函数参数传递
在C语言中,二维数组实际上是一种特殊的一维数组,它的每个元素也是一个一维数组。因此,二维数组下标形式正确写法如下:int
arrays[i][j]
规定:如果将二维数组作为参数传递给函数,那么在函数的参数声明中必须指明数组的列数,数组的行数没有太大关系,可以指定也可以不指定。因为函数调用时传递的是一个指针,它指向由行向量够成的一维数组。因此二维数组作为函数参数正确写法如下所示:
<span style="font-size:14px;">void Func(int array[3][10]);
void Func(int array[ ][10]);</span>
因为数组的行数无关紧要,所以还可以写成如下形式:
<span style="font-size:14px;">void Func(int (*array)[10]); 注意*array需要用括号括起来</span>
需要指定列的原因是:
对于数组 int p[m][n],如果要取p[i][j]的值(i>=0 && i<m && 0<=j && j < n),编译器是这样寻址的,它的地址为:
p + i*n + j;
如果我们省略了第二维或者更高维的大小,编译器将不知道如何正确的寻址。
2.对数组进行sizeof操作
首先,sizeof是一个关键字而不是一个宏或者库函数,它的结果在编译期间获得。
如果一个数组的大小不能在编译期间获得,那么就不能使用sizeof获取数组的大小。
sizeof返回的永远都是一个对象或者类型所占用的字节个数。
int a[10];
cout << sizeof(a) << endl; //40
char b[10];
cout << sizeof(b) << endl; //10
将数组名作为参数传递给函数后,数组类型退化为指针类型,这时sizeof的结果变成指针的大小。
void test(int c[])
{
cout << sizeof(c) << endl;
}
int _tmain(int argc, _TCHAR* argv[])
{
int a[10];
cout << sizeof(a) << endl; //40
char b[10];
cout << sizeof(b) << endl; //10
test(a); //退化成指针类型,大小为4
return 0;
}