16

为什么在下面的函数中n不等于?8

void foo(char cvalue[8])
{
  int n = sizeof (cvalue);
}

但在这个版本的函数n 等于:8

void bar()
{
  char cvalue[8];
  int n = sizeof (cvalue);
}
4

4 回答 4

47

因为您不能将整个数组作为 C 中的函数参数传递。您实际上是在传递一个指向它的指针;括号是语法糖。不能保证您指向的数组大小为 8,因为您可以向此函数传递您想要的任何字符指针。

// These all do the same thing
void foo(char cvalue[8])
void foo(char cvalue[])
void foo(char *cvalue)
于 2008-09-08T02:35:55.923 回答
14

C 和 C++ 数组不是一流的对象;您不能将数组传递给函数,它们总是衰减为指针。

但是,您可以将指针和引用传递给数组。这可以防止数组边界衰减。所以这是合法的:

template<typename T, size_t N>
void foo(const T(&arr)[N])
{
    int n = sizeof(arr);
}
于 2008-09-08T13:03:29.580 回答
1

在第一个示例中,作为传递参数的 cvalue 实际上只是一个指向字符数组的指针,当您使用sizeof()它时,您会得到指针的大小。在第二种情况下,您已将其声明为局部变量,您将获得整个数组的大小。

于 2008-09-08T02:41:28.623 回答
0

参数的大小在 32 位系统上将为 4,而在使用 -m64 编译的 64 位系统上将为 8。这是因为数组在函数中作为指针传递。指针只是一个内存地址。

于 2008-09-08T03:39:14.740 回答