STL迭代器失效

迭代器失效的问题(C++ Primer p315)

面试中的典型问题:对于某一具体的容器(如vector)的迭代器失效问题。

向容器添加或删除元素都有可能使容器的部分或全部迭代器失效,结合具体实现容器的数据结构分析:

  • 向vector与string等基于可变数组的容器添加元素的情况下需要考虑内存是否重置
  • 序列容器实现的底层数据结构:动态数组(vector,string),链表(list,forward_list),分段连续的数组(deque)。
  • 关联容器实现的底层数据结构:红黑树,哈希表

使用迭代器删除元素

序列性容器

对于基于动态数组与分段连续的数组实现的容器(vector,string,deque),erase迭代器不仅使所指向被删元素的迭代器失效,而且使被删元素之后的所有迭代器失效,所以不能使用erase(iter++)的方式,但是erase的返回值为下一个有效的迭代器。

删除的正确姿势:

for(iter = c.begin(); iter != c.end(); )
    iter = c.erase(iter);

关联性容器

关联容器实现的底层数据结构为红黑树与哈希表(开散列),元素之间是通过指针联系的,erase迭代器只是被删元素的迭代器失效,但是返回值为void,所以要采用erase(iter++)的方式删除迭代器。

删除的正确姿势:

for(iter = c.begin(); iter != c.end(); )  
    c.erase(iter++);

PS:对于list与forward_list基于链表实现的容器,以上两种删除方式都可以的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值