关于迭代器失效
2011-06-20 16:23
197 查看
调用STL的erase函数后,会导致迭代器失效
错误代码:
for
(iter
=
vec.begin()
+
1
, end
=
vec.end(); iter
!=
end;
++
iter)
{
if
(
*
iter
==
previous)
{
vec.erase(iter);
}
else
{
previous
=
*
iter;
}
}
正确代码:
1. 对于关联容器(如map, set, multimap,multiset),删除当前的iterator,仅仅会使当前的iterator失效,只要在erase时,递增当前iterator即可。这是因为map之类的容器,使用了红黑树来实现,插入、删除一个结点不会对其他结点造成影响。
for
(iter
=
cont.begin(); it
!=
cont.end();)
{
(
*
iter)
->
doSomething();
if
(shouldDelete(
*
iter))
cont.erase(iter
++
);
else
++
iter;
}
2. 对于序列式容器(如vector,deque),删除当前的iterator会使后面所有元素的iterator都失效。这是因为vetor,deque使用了连续分配的内存,删除一个元素导致后面所有的元素会向前移动一个位置。还好erase方法可以返回下一个有效的iterator
。
for
(iter
=
cont.begin(); iter
!=
cont.end();)
{
(
*
it)
->
doSomething();
if
(shouldDelete(
*
iter))
iter
=
cont.erase(iter);
else
++
iter;
}
3. 对于list来说,它使用了不连续分配的内存,并且它的erase方法也会返回下一个有效的iterator,因此上面两种方法都可以使用。
错误代码:
for
(iter
=
vec.begin()
+
1
, end
=
vec.end(); iter
!=
end;
++
iter)
{
if
(
*
iter
==
previous)
{
vec.erase(iter);
}
else
{
previous
=
*
iter;
}
}
正确代码:
1. 对于关联容器(如map, set, multimap,multiset),删除当前的iterator,仅仅会使当前的iterator失效,只要在erase时,递增当前iterator即可。这是因为map之类的容器,使用了红黑树来实现,插入、删除一个结点不会对其他结点造成影响。
for
(iter
=
cont.begin(); it
!=
cont.end();)
{
(
*
iter)
->
doSomething();
if
(shouldDelete(
*
iter))
cont.erase(iter
++
);
else
++
iter;
}
2. 对于序列式容器(如vector,deque),删除当前的iterator会使后面所有元素的iterator都失效。这是因为vetor,deque使用了连续分配的内存,删除一个元素导致后面所有的元素会向前移动一个位置。还好erase方法可以返回下一个有效的iterator
。
for
(iter
=
cont.begin(); iter
!=
cont.end();)
{
(
*
it)
->
doSomething();
if
(shouldDelete(
*
iter))
iter
=
cont.erase(iter);
else
++
iter;
}
3. 对于list来说,它使用了不连续分配的内存,并且它的erase方法也会返回下一个有效的iterator,因此上面两种方法都可以使用。
相关文章推荐
- 关于迭代器失效的一些认识
- c++关于顺序容器指针迭代器失效问题
- 关于迭代器失效的讨论
- 关于迭代器失效的一些认识
- c++关于顺序容器指针迭代器失效问题
- 迭代器的使用--关于迭代器的失效
- 关于STL的erase()陷阱-迭代器失效问题的总结
- 关于list循环删除元素,迭代器失效的问题
- 数据结构::关于迭代器失效
- 关于迭代器失效
- 有关于STL中的迭代器失效问题[转自CSDN BLOG]
- 关于迭代器失效的一些认识
- C++关于迭代器删除(erase)插入(insert)失效问题http://m.blog.csdn.net/blog/a327369238/26715187
- C++关于迭代器删除(erase)插入(insert)失效问题
- 关于vector的erase操作后,迭代器失效问题
- 关于迭代器失效的一些认识
- 关于STL顺序容器迭代器失效
- 关于httpclient 连接失效引发的问题
- 关于百度地图在打包签名后key验证失效的坑
- C++ STL 迭代器失效问题的剖析