正确使用STL-MAP中Erase函数
2013-05-09 15:13
323 查看
#include <iostream> #include <map> #include <string> using namespace std ; int main(void) { map<int, string> m ; m.insert(pair<int, string>(1, "abc")) ; m.insert(pair<int, string>(2, "def")) ; m.insert(pair<int, string>(3, "def")) ; m.insert(pair<int, string>(4, "ghi")) ; map<int, string>::iterator itor ; // 错误的写法 for (itor = m.begin(); itor != m.end(); ++itor) { if (itor->second == "def") { m.erase(itor) ; // map是关联式容器,调用erase后,当前迭代器已经失效 } } // 正确的写法 for (itor = m.begin(); itor != m.end();) { if (itor->second == "def") { m.erase(itor++) ; // erase之后,令当前迭代器指向其后继。 } else { ++itor; } } // 另一个正确的写法,利用erase的返回值,注意,有些版本的stl-map没有返回值,比如SGI版,但vc版的有 for (itor = m.begin(); itor != m.end();) { if (itor->second == "def") { itor = m.erase(itor) ; // erase的返回值是指向被删除元素的后继元素的迭代器 } else { ++itor; } } // Print m map<int, string>::const_iterator citor ; for (citor = m.begin(); citor != m.end(); ++citor) { cout << citor->first << ":" << citor->second << endl ; } getchar() ; return 0 ; }
相关文章推荐
- 正确使用STL-MAP中Erase函数
- 正确使用STL-MAP中Erase函数 一切尽在代码中。
- 正确使用STL-MAP中Erase函数
- 正确使用STL-MAP中Erase函数
- 正确使用STL-MAP中Erase函数
- STL中使用reverse_iterator时,如何正确使用erase函数
- 正确的在遍历过程中使用STL容器的erase函数
- map, set, vector 的erase函数的正确使用方法
- 自己构建的哈希表,使用起来比STL的map更加方便
- 3.1.3 STL中list、map、vector的使用方法
- 使用linux的GDB打印STL(vector,map,set..................)
- stl 复习:map使用
- 关于stl中map使用体会
- STL容器使用DEMO-map
- STL之Map使用小结
- STL之set、map基本使用实例
- C++中防止STL中迭代器失效__map/set等关联容器vector/list/deque等序列容器_如何防止迭代器失效_即erase()的使用
- stl之map使用.cpp
- STL hash_map使用
- STL中的map表的使用问题