在c++++中实现变长数组主要有两种方法:手动动态分配内存和使用标准库容器vector。手动动态分配内存通过new申请空间并在需要时重新分配更大空间拷贝旧数据删除旧内存更新指针这种方式灵活但易出错因此仅适用于对性能有特殊要求或需定制化内存管理的场景;更推荐使用vector它自动管理内存提供丰富接口可像普通数组一样访问元素插入元素时自动扩容通常以当前容量两倍增长且无需担心内存泄漏在大多数应用开发中优先使用vector是高效且安全的选择。

在C++中,标准的数组类型是定长的,编译时就必须确定大小。但很多时候我们并不知道需要多少空间,这时候就需要用“变长数组”来应对动态变化的数据量。实现变长数组的方法主要有两种:手动动态分配内存和使用标准库容器。

动态分配内存:new 和 delete
如果你不想依赖标准库或者有特殊性能要求,可以使用 new 来手动申请内存,实现一个简单的变长数组。
int* arr = new int[10]; // 初始分配10个int的空间 // 使用完成后记得释放 delete[] arr;
当数组不够用时,你可以重新分配一块更大的空间,把原来的数据拷贝过去,再释放旧空间:
立即学习“C++免费学习笔记(深入)”;

- 分配新内存(比如原来2倍)
- 拷贝旧数据到新内存
- 删除旧内存
- 更新指针指向新内存
这种方式虽然灵活,但容易出错,比如忘记释放、内存泄漏、浅拷贝等问题都需要你自己处理。因此,除非你对性能有非常严格的要求,否则不建议直接这么做。
更推荐的方式:使用标准容器 vector
C++标准库提供了 std::vector,它本质上就是一个封装好的“变长数组”,自动管理内存,使用起来既方便又安全。

#includestd::vector vec; vec.push_back(1); // 自动扩容 vec.push_back(2);
- 不用手动管理内存,不用担心内存泄漏
- 提供丰富的接口:如
size(),capacity(),resize()等 - 可以像普通数组一样访问元素:
vec[i] - 插入元素会自动扩容,通常是以当前容量两倍的方式增长
如果你只是想存一组数量不确定的数据,vector 几乎是首选方案。
什么时候该自己分配?什么时候用 vector?
有些时候你可能还是得自己控制内存:
- 需要高度定制化的内存管理(比如嵌入式系统或游戏引擎底层)
- 对性能极度敏感,需要避免 vector 的一些额外开销
- 或者你想练习 C++ 内存操作的基本功
但在大多数应用开发中,优先使用 vector 是更高效也更安全的选择。
基本上就这些。变长数组的实现方式在 C++ 中很灵活,根据你的项目需求选择合适的方法就行。










