迭代器失效问题

迭代器失效问题简析

迭代器失效(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 后务必使用其返回值,而非原迭代器。

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

相关推荐
tankeven5 小时前
C++ 学习杂记00:标准模板库(STL)
c++
blog_wanghao5 小时前
条款03:尽可能使用const
c++
Rabitebla5 小时前
【C++】手撕日期类——运算符重载完全指南(含易错点+底层逻辑分析)
java·c语言·开发语言·数据结构·c++·算法·链表
艾莉丝努力练剑5 小时前
【Linux线程】Linux系统多线程(九):线程池实现(附代码示例)
linux·运维·服务器·c++·学习·架构
tankeven5 小时前
C++ 学习杂记01:C++ vector 容器详细
c++
艾莉丝努力练剑5 小时前
【Linux线程】Linux系统多线程(八):<策略模式>日志系统的封装实现
linux·运维·服务器·c++·学习·策略模式
盐焗鹌鹑蛋5 小时前
【C++】string模拟实现
c++
特种加菲猫5 小时前
C++进阶:模板深度解析与继承机制初探
开发语言·c++
旖-旎5 小时前
递归(快速幂)(5)
c++·算法·力扣·递归
大江东去浪淘尽千古风流人物8 小时前
【cuVSLAM】GPU 加速、多相机、实时视觉/视觉惯性 SLAM设计优势
c++·人工智能·数码相机·ubuntu·计算机视觉·augmented reality