C++中vector是STL常用动态数组容器,支持自动内存管理与随机访问。可空初始化、指定大小或初值、用数组或其他vector初始化,C++11起支持列表初始化。常用操作包括push_back添加元素,下标或at访问,front/back获取首尾,pop_back/erase删除,size/empty/capacity查询状态,clear清空。配合迭代器可正向、反向遍历,C++11范围for更简洁。注意避免频繁中间插入删除,扩容会导致迭代器失效,建议reserve预分配空间,多维用vector<vector<int>>,传参用const引用防拷贝。熟练掌握vector初始化与操作是C++开发基本功。

在C++中,vector 是标准模板库(STL)中最常用的一种动态数组容器。它能自动管理内存,支持随机访问,并且可以在运行时动态添加或删除元素。掌握 vector 的初始化和使用方法对编写高效、安全的 C++ 程序至关重要。
vector 的常见初始化方式
vector 提供了多种初始化方法,适用于不同场景:
- 空初始化:创建一个空的 vector,后续可通过 push_back 添加元素。
vector<int> vec; - 指定大小初始化:创建指定数量的默认值元素。
vector<int> vec(5); // 包含5个0 - 指定大小和初始值:
vector<int> vec(5, 10); // 5个元素,每个都是10 - 用数组初始化:
int arr[] = {1, 2, 3};
vector<int> vec(arr, arr + 3); - 用另一个 vector 初始化:
vector<int> vec1 = {1, 2, 3};
vector<int> vec2(vec1); - 列表初始化(C++11 起):
vector<int> vec = {1, 2, 3, 4, 5};
vector 的基本操作与使用方法
vector 支持丰富的成员函数,便于日常开发使用。
- 添加元素:使用 push_back 在尾部添加元素。
vec.push_back(6); - 访问元素:
- 下标访问:vec[0](不检查越界)
- at 方法:vec.at(0)(带越界检查,越界抛出异常)
- front() 和 back() 分别获取首尾元素
- 删除元素:
- pop_back() 删除最后一个元素
- erase() 删除指定位置或范围的元素
vec.erase(vec.begin()); // 删除第一个
- 查询大小:
- size():当前元素个数
- empty():判断是否为空,推荐代替 size()==0
- capacity():当前分配的存储容量
- resize():调整 vector 大小
- 清空内容:
vec.clear();
vector 与迭代器的配合使用
vector 支持使用迭代器遍历元素,是 STL 算法的基础。
立即学习“C++免费学习笔记(深入)”;
- 正向遍历:
for(auto it = vec.begin(); it != vec.end(); ++it) {
cout << *it << ” “;
} - 反向遍历:
for(auto rit = vec.rbegin(); rit != vec.rend(); ++rit) {
cout << *rit << ” “;
} - C++11 范围 for 循环更简洁:
for(int x : vec) {
cout << x << ” “;
}
vector 使用注意事项
虽然 vector 使用方便,但也需注意一些关键点:
- 频繁插入或删除中间元素效率较低,因需移动后续元素
- push_back 可能导致扩容,原有指针或迭代器失效
- 尽量使用 reserve() 预分配空间以提升性能
- 多维 vector 可通过 vector<vector<int>> 实现
- 传参时建议使用引用避免拷贝开销:void func(const vector<int>& v)
基本上就这些。vector 封装了动态数组的复杂性,合理使用能大幅提升编码效率和程序稳定性。熟练掌握其初始化和操作方法,是 C++ 开发的基本功。


