首先,这是一些代码:
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个字节)?
不,你不能。编译器不知道指针指向什么。有一些技巧,例如以一个已知的带外值结束数组,然后计算大小直到该值,但这并不使用sizeof。
[另一个技巧是Zan提到的技巧,将大小存储在某个地方。例如,如果要动态分配数组,请分配一个比所需块大一个int的块,将大小存储在第一个int中,并返回ptr + 1作为指向数组的指针。当需要大小时,减少指针并偷看隐藏的值。只要记住要从头开始释放整个块,而不仅仅是数组。
答案是“否”
C程序员要做的是将数组的大小存储在某个地方。它可以是结构的一部分,或者程序员可以作弊,并且malloc()的内存比请求的多,以便在数组开始之前存储长度值。
对于动态数组(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)会更安全,更易于使用。
sizeof()