STL容器迭代过程中删除元素技巧(转)
来源:互联网 发布:网络教育不能考公务员 编辑:程序博客网 时间:2024/05/21 17:05
1.连续内存序列容器(vector,string,deque)
序列容器的erase方法返回值是指向紧接在被删除元素之后的元素的有效迭代器,可以根据这个返回值来安全删除元素。
vector<int> c;
for(vector<int>::iterator it = c.begin(); it != c.end();)
{
if(need_delete())
it = c.erase(it);
else
++it;
}
2.关联容器(set,multiset,map,multimap)
关联容器的erase方法没有返回值,被删除的迭代器失效,所以删除前必须确保能得到下一个迭代器,可以用“后置递增迭代器”技术。
map<int,int> m;
for(map<int,int>::iterator it = m.begin(); it != m.end();)
{
if(need_delete())
m.erase(it++);
else
++it;
}
m.erase得到it的一个副本,在erase真正开始之前it已经递增了。
所以erase得到了当前的迭代器,在erase内部工作开始之前it已经++了,正好满足我们的需要。
3.非连续内存序列容器(list)
只所以单独列出来是因为以上两种方法对list都适用,可依自己喜好选择。
From:http://www.cnblogs.com/ggjucheng/archive/2012/01/03/2310973.html
iterator erase( iterator pos );
对C++ STL中迭代器的删除需要慎重,如上方法。
1、vector
vector在遍历中进行 erase(pos) ,这个时候iter++的时候会出现bug,会跳过一个字段或者coredump。
解决方法:(要删除的时候直接赋值返回值,但是不能++)
- vector<int>::iterator iter2;
- for(iter2 = vec.begin(); iter2 != vec.end(); )
- {
- printf("%d " , *iter2 ); //注意这里
- if( *iter2 == 3 ){
- iter2 = vec.erase( iter2 );
- }else{
- iter2++;
- }
- }
2、list
list在遍历中进行 erase(pos) ,这个时候iter++的时候会出现bug,会直接coredump。
解决方案:
- list<int>::iterator iter2;
- for(iter2 = vec.begin(); iter2 != vec.end(); iter2++)
- {
- printf("%d " , *iter2 );
- if( *iter2 == 3 ){
- vec.remove( *iter2 ); //注意这里,调用remove( const TYPE &val );
- }
- }
3、map
list在遍历中进行 erase(pos) ,这个时候iter++的时候会出现bug,会出现未知问题。
解决方案:
- map<int,int>::iterator iter;
- for(iter = testMap.begin(); iter != testMap.end(); iter++)
- {
- printf("%d " , iter->second );
- if( iter->second == 3 )
- {
- testMap.erase( iter->first ); //注意这里,是通过key删除
- }
- }
0 0
- STL容器迭代过程中删除元素技巧(转)
- STL容器迭代过程中删除元素技巧(转)
- STL容器迭代过程中删除元素技巧(转)
- STL容器迭代删除元素
- STL在迭代的过程中,删除指定的元素
- STL容器:在遍历的过程中删除元素
- STL容器删除元素的陷阱(转)
- stl在遍历过程中删除元素
- STL容器元素的删除
- stl容器遍历删除元素
- STL容器之 元素删除
- 安全删除STL容器元素
- 总结STL中容器中元素的删除方法
- 删除STL list容器中元素使用经验分享
- STL:循环删除容器中元素的方法和陷阱
- STL:循环删除容器中元素的方法和陷阱
- FAQ14: STL中vector容器如何间隔删除元素?
- STL 删除容器中元素的几个特殊问题
- 数据库设计(一对一、一对多、多对多)
- javax.net.ssl.SSLHandshakeException:sun.security.validator.ValidatorException: PKIX path building失败
- Maven实践(二) 下载、安装和配置
- Shell特殊变量:Shell $0, $#, $*, $@, $?, $$和命令行参数
- uint8_t / uint16_t / uint32_t /uint64_t数据类型
- STL容器迭代过程中删除元素技巧(转)
- Android获取系统的硬件信息、系统版本以及如何检测ROM类型
- 《Drools6.4 中文文档》第1章1.3(完)
- springmvc-学习笔记(2)
- 1-4 bootloader初探
- javascript中的正则表达式
- 控件相对主框架移动
- 札记2:CentOS6(64位)与本机(Win7 64位)网络映射
- linux i2c子系统代码分析5 ---操作函数i2c_new_device i2c_new_probed_device i2c_register_board_info介绍