C语言的各种

本文介绍了C语言中二维数组作为函数参数的正确传递方式,包括必须指明列数的原因及数组退化为指针类型后的sizeof操作结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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;
}







评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值