为什么在下面的函数中n
不等于?8
void foo(char cvalue[8])
{
int n = sizeof (cvalue);
}
但在这个版本的函数n
中等于:8
void bar()
{
char cvalue[8];
int n = sizeof (cvalue);
}
因为您不能将整个数组作为 C 中的函数参数传递。您实际上是在传递一个指向它的指针;括号是语法糖。不能保证您指向的数组大小为 8,因为您可以向此函数传递您想要的任何字符指针。
// These all do the same thing
void foo(char cvalue[8])
void foo(char cvalue[])
void foo(char *cvalue)
C 和 C++ 数组不是一流的对象;您不能将数组传递给函数,它们总是衰减为指针。
但是,您可以将指针和引用传递给数组。这可以防止数组边界衰减。所以这是合法的:
template<typename T, size_t N>
void foo(const T(&arr)[N])
{
int n = sizeof(arr);
}
在第一个示例中,作为传递参数的 cvalue 实际上只是一个指向字符数组的指针,当您使用sizeof()
它时,您会得到指针的大小。在第二种情况下,您已将其声明为局部变量,您将获得整个数组的大小。
参数的大小在 32 位系统上将为 4,而在使用 -m64 编译的 64 位系统上将为 8。这是因为数组在函数中作为指针传递。指针只是一个内存地址。