迭代器失效问题

迭代器失效问题简析

迭代器失效(Iterator Invalidation)是指:在容器发生修改后,原有迭代器不再指向合法、有效的元素位置 。继续使用失效的迭代器会导致未定义行为(UB),即使程序看似"正常运行"。

为什么失效?

迭代器失效不等于指针悬空。它本质是语义失效------迭代器所代表的逻辑位置已不存在,原因包括:

  • 元素被删除或移动(如 vector::erase
  • 容器重新分配内存(如 vector 扩容)
  • 哈希表 rehash(如 unordered_map::insert

✅ 注意:即使底层内存未释放,迭代器也可能失效!

常见容器行为

常见容器的迭代器失效规则

容器 插入导致失效 删除导致失效
vector 扩容:全部失效;否则:插入点及之后失效 删除点及之后失效
string vector(因实现为连续字符数组) vector
deque 通常所有迭代器失效 通常所有迭代器失效
list / forward_list 无失效(除被删/插位置自身) 仅被删元素的迭代器失效
map / set 无失效 仅被删元素的迭代器失效
unordered_* rehash 时全部失效 仅被删元素的迭代器失效

安全示例

cpp 复制代码
// 正确:使用 erase 返回值
for (auto it = vec.begin(); it != vec.end(); ) {
    if (*it % 2 == 0)
        it = vec.erase(it);  // it 被更新为下一个有效位置
    else
        ++it;
}

关键原则

不要在修改容器后继续使用旧迭代器(除非确认安全,如 list)。 erase 后务必使用其返回值,而非原迭代器。

理解你所用容器的失效规则,比依赖"看起来能跑"更可靠。

相关推荐
不想写代码的星星8 小时前
std::function 详解:用法、原理与现代 C++ 最佳实践
c++
樱木Plus2 天前
深拷贝(Deep Copy)和浅拷贝(Shallow Copy)
c++
blasit4 天前
笔记:Qt C++建立子线程做一个socket TCP常连接通信
c++·qt·tcp/ip
肆忆_5 天前
# 用 5 个问题学懂 C++ 虚函数(入门级)
c++
不想写代码的星星5 天前
虚函数表:C++ 多态背后的那个男人
c++
端平入洛7 天前
delete又未完全delete
c++
端平入洛8 天前
auto有时不auto
c++
哇哈哈20219 天前
信号量和信号
linux·c++
多恩Stone9 天前
【C++入门扫盲1】C++ 与 Python:类型、编译器/解释器与 CPU 的关系
开发语言·c++·人工智能·python·算法·3d·aigc
蜡笔小马9 天前
21.Boost.Geometry disjoint、distance、envelope、equals、expand和for_each算法接口详解
c++·算法·boost