vector是C++ STL中自动管理内存的动态数组,支持随机访问和尾部快速增删;声明需指定类型,如vector v(5)或vector v{‘a’,‘b’};常用操作包括push_back、pop_back、insert、erase、at等。
vector 是 C++ 标准模板库(STL)中最常用、最实用的容器之一,本质是“自动管理内存的动态数组”。它支持随机访问、尾部快速增删,用起来像数组但不用手动 new/delete,也不用担心越界(调试模式下会报错)。掌握 vector,就掌握了 STL 入门的钥匙。
vector 是模板类,必须指定元素类型。常见写法有:
std::vector v; —— 创建空 int 向量std::vector v(5); —— 5 个 0.0std::vector v(3, 'a'); —— {'a','a','a'}std::vector v = {1, 2, 3, 4}; 或 std::vector v{1,2,3};
std::vector v2 = v1; 或 std::vector v2(v1);
所有操作都通过成员函数完成,不依赖下标(除非你明确要访问):
v.push_back(x) —— 时间均摊 O(1)v.pop_back() —— O(1),不返回值(可用 v.back() 先取)v.insert(v.begin() + i, x) —— 在第 i 个位置前插入,O(n)v.erase(v.begin() + i) 或 v.erase(v.begin()+i, v.begin()+j)
v[i](不检查边界)、v.at(i)(带越界检查,抛出 std::out_of_range)v.front()、v.back() —— 对非空 vector 才安全理解这两个概念,能避免频繁内存重分配,提升性能:
例如:v.reserve(1000); 后连续 push_back 900 次,基本不会触发扩容。
推荐按场景选择,兼顾清晰性与安全性:
for (int i = 0; i —— 简单直接,注意用 size
_t 或 auto 避免隐式转换警告
for (auto x : v) ...(值拷贝)或 for (const auto& x : v) ...(推荐,避免拷贝)for (auto it = v.begin(); it != v.end(); ++it) ... —— 灵活,配合算法使用多std::for_each(v.begin(), v.end(), [](int x){ cout
基本上就这些。vector 不复杂,但细节决定健壮性——比如别对空 vector 调用 front/back,insert/erase 后迭代器可能失效,循环中删元素要小心迭代器偏移。用熟了,它比原生数组更可靠、更高效。