正确删除vector元素需避免迭代器失效,首选erase-remove惯用法:删除单个元素用vec.erase(iter);删除特定值用vec.erase(std::remove(vec.begin(), vec.end(), value), vec.end());删除满足条件的元素用std::remove_if配合erase;遍历中删除应使用it = vec.erase(it)获取下一个有效迭代器,防止访问越界。

在C++中删除
vector中的元素看似简单,但如果不注意方法,容易引发迭代器失效、越界访问等问题。正确使用标准库提供的机制是关键。
使用 erase() 删除单个或多个元素
最直接的方式是通过
erase()函数删除指定位置的元素:
vec.erase(iter)
:删除迭代器指向的单个元素vec.erase(start, end)
:删除一个范围内的元素
例如:
std::vector
auto it = vec.begin() + 2; // 指向3
vec.erase(it); // 删除元素3,结果为 {1,2,4,5}
结合 remove/erase 惯用法删除特定值
若要删除所有等于某个值的元素,应使用 erase–remove 惯用法:
立即学习“C++免费学习笔记(深入)”;
vec.erase(std::remove(vec.begin(), vec.end(), value), vec.end());
std::remove
将所有不等于value
的元素前移,并返回新的“尾部”迭代器erase()
负责真正释放后面多余的部分
这种方法高效且不会导致迭代器问题。
删除满足条件的元素(如偶数)
使用
std::remove_if配合
erase可删除符合谓词的元素:
vec.erase(std::remove_if(vec.begin(), vec.end(),
[](int n) { return n % 2 == 0; }), vec.end());
- 这个例子会删除所有偶数
- lambda 表达式定义判断逻辑
遍历中安全删除元素的方法
如果需要在循环中根据条件逐个删除元素,必须小心处理迭代器:
for (auto it = vec.begin(); it != vec.end();) {
if (*it == target) {
it = vec.erase(it); // erase 返回下一个有效迭代器
} else {
++it;
}
}
- 不能在
erase
后继续使用原迭代器 erase()
返回的是下一个有效位置,应将其赋给迭代器
基本上就这些。关键是避免手动递增已被销毁的迭代器,优先使用
erase-remove模式处理批量删除。只要遵循这些做法,vector 元素删除就能既安全又高效。











