关于sizeof在调用函数中获取被调函数数组长度的思考
我们知道, 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 ", 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 ", arr[i]); } return 0; }输出:
我们将传递的参数改为&arr,它的类型是int* [5] 类型,指向整个数组。所以在接收时,用int (*a)[5]来接收,这里要注意,由于它的类型是int* [5]类型,所以形参[ ]内必须写上5。这样我们就可以通过sizeof(*a)求得被调函数中数组的长度了,就可以正常给数组赋值。
声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。