gpt4 book ai didi

c++ - 指向数组的指针和错误 C2057、C2540

转载 作者:太空狗 更新时间:2023-10-29 21:42:00 25 4
gpt4 key购买 nike

我想做这样的事情:

const int N = 10;
void foo (const int count)
{
int (* pA) [N][count] = reinterpret_cast<int(*)[N][count]>(new int[N * count]);
...
}

但我的编译器 (VS2010) 不想这样做:

error C2057: expected constant expression
error C2540: non-constant expression as array bound

这样表达他对计数的不满。

我知道如何通过实现稍微不同的方式来解决这个问题。但我只是不明白,为什么 C++ 禁止我使用这种 方式。我明白,为什么 C++ 需要在编译时知道栈上数组的大小(以分配数组内存)。但是为什么对于指向数组的指针需要同样的限制(毕竟,指针只是使用分配的内存的一种工具)?

最佳答案

嗯,实际上你想要的在原则上是好的,但是你使用了错误的语法。

除了第一个维度之外的所有维度都必须是编译时常量,因为它们用于指针运算。第一个可以是运行时变化的。这有效:

int (* pA)[N] = new int[count][N];

请记住,数组与指向元素的指针类型兼容,并且下标在两者上的工作方式完全相同。因此,当您分配了一个二维数组(数组的数组)时,您应该存储一个指向一维数组的指针。

不过,没有办法执行 int[N][count],因为这需要一个可变大小的元素数组(子数组)。

此外,请注意 N 是一个常量表达式,但 count 不是。即使它们具有相同的类型,count 也是一个参数,在运行时确定。

如果你想接受一个常量整数表达式作为参数,将它设为模板参数:

template <int count>
void foo()

现在 count 是一个常量表达式,就像 N 一样。

关于c++ - 指向数组的指针和错误 C2057、C2540,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27472776/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com