牛骨文教育服务平台(让学习变的简单)
博文笔记

关于sizeof在调用函数中获取被调函数数组长度的思考

创建时间:2016-06-14 投稿人: 浏览次数:1012

  我们知道, 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)求得被调函数中数组的长度了,就可以正常给数组赋值。

声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。