3

我想做类似的事情:

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

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

错误 C2057:预期
的常量表达式错误 C2540:非常量表达式作为数组绑定

他以这样的方式表达了他的不满count

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

4

1 回答 1

2

好吧,实际上您想要的原则上是可以的,但是您使用了错误的语法。

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

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

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

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

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

如果要接受常量整数表达式作为参数,请将其设为模板参数:

template <int count>
void foo()

Nowcount是一个常量表达式,就像N.

于 2014-12-14T19:07:48.600 回答