可变长度数组

我想知道如何管理可变长度数组(为了拥有可变长度数组,在堆栈上保留了哪些额外的变量或数据结构)。

非常感谢。

它只是一个动态大小的数组(依赖于实现,但最常见于堆栈)。 它与过去的alloca非常相似,只有sizeof会返回数组的实际大小,这意味着数组的大小也必须存储在某个地方(依赖于实现,但也可能在堆栈上) )。

可变长度数组的大小是在运行时确定的,而不是编译时间。
它的管理方式取决于编译器。
例如,GCC在堆栈上分配内存。
但是没有特殊的结构。 它只是一个普通的数组,其大小在运行时已知。

或者你可以使用一些容器,例如java中的ArrayList或c / c ++中的vector