迭代器失效的问题(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基于链表实现的容器,以上两种删除方式都可以的。