如何找到'sizeof'(指向数组的指针)?

问题描述 投票:285回答:13

首先,这是一些代码:

int main() 
{
    int days[] = {1,2,3,4,5};
    int *ptr = days;
    printf("%u\n", sizeof(days));
    printf("%u\n", sizeof(ptr));

    return 0;
}

是否有办法找出ptr指向的数组的大小(而不是仅仅给出其大小,在32位系统上为4个字节)?

c arrays pointers sizeof
13个回答
247
投票

不,你不能。编译器不知道指针指向什么。有一些技巧,例如以一个已知的带外值结束数组,然后计算大小直到该值,但这并不使用sizeof。

[另一个技巧是Zan提到的技巧,将大小存储在某个地方。例如,如果要动态分配数组,请分配一个比所需块大一个int的块,将大小存储在第一个int中,并返回ptr + 1作为指向数组的指针。当需要大小时,减少指针并偷看隐藏的值。只要记住要从头开始释放整个块,而不仅仅是数组。


2
投票

1
投票

0
投票

-1
投票

76
投票

答案是“否”

C程序员要做的是将数组的大小存储在某个地方。它可以是结构的一部分,或者程序员可以作弊,并且malloc()的内存比请求的多,以便在数组开始之前存储长度值。


45
投票

对于动态数组(malloc或C ++ new),您需要存储其他人提到的数组大小,或者可能需要构建一个数组管理器结构来处理添加,删除,计数等。不幸的是C几乎不像C ++那样做,因为您基本上必须为要存储的每种不同的数组类型构建它,如果您需要管理多种类型的数组,这将很麻烦。

对于静态数组,例如您的示例中的数组,有一个公共宏用于获取大小,但是它是[[不推荐

,因为它不检查参数是否真的是静态数组。不过,该宏用于实际代码中,例如在Linux内核头文件中,尽管它可能与以下内容略有不同:#if !defined(ARRAY_SIZE) #define ARRAY_SIZE(x) (sizeof((x)) / sizeof((x)[0])) #endif int main() { int days[] = {1,2,3,4,5}; int *ptr = days; printf("%u\n", ARRAY_SIZE(days)); printf("%u\n", sizeof(ptr)); return 0; }
您可以出于某种原因使用Google来警惕此类宏。小心。

如果可能的话,C ++ stdlib(例如vector)会更安全,更易于使用。


18
投票
使用C ++模板有一个干净的解决方案,而不使用

sizeof()


5
投票

4
投票

4
投票

2
投票

2
投票
© www.soinside.com 2019 - 2024. All rights reserved.