我们知道, sizeof 是一个操作符,其作用是返回一个操作数所占的内存字节数。那么在函数调用中,如何求一个被调函数数组的长度呢?
现在我们来看下面的示例代码:
#include <stdio.h>
void f(int a[])
{
for(int i=0; i<sizeof(a)/sizeof(int); ++i){
a[i] = i;
}
}
int main()
{
int arr[5] = {0};
f (arr);
for(int i=0; i<5; ++i){
printf("%d\n", arr[i]);
}
return 0;
}
在这段程序中,我们尝试在f()函数中对数组初始化,其中初始化时用到了sizeof求数组长度。它的输出结果是这样的:
为什么只有前两个数赋值成功了呢?
原因是,我们在函数调用传参过程中,所传递的参数是arr,它在传递的过程中退化成了指针,那么sizeof(arr)就相当于sizeof(int *),在64位机器里面,占8个字节。所以sizeof(arr)/sizeof(int) = 2,那么只有数组的前两个成员被赋值成功,其他成员仍然为0。
那么,我们如何来解决这个问题呢,通过下面这种方式就可以。
#include <stdio.h>
void f(int (*a)[5])
{
for(int i=0; i<sizeof(*a)/sizeof(int); ++i){
(*a)[i] = i;
}
}
int main()
{
int arr[5] = {0};
f (&arr);
for(int i=0; i<5; ++i){
printf("%d\n", arr[i]);
}
return 0;
}
输出:
我们将传递的参数改为&arr,它的类型是int* [5] 类型,指向整个数组。所以在接收时,用int (*a)[5]来接收,这里要注意,由于它的类型是int* [5]类型,所以形参[ ]内必须写上5。这样我们就可以通过sizeof(*a)求得被调函数中数组的长度了,就可以正常给数组赋值。