zoukankan      html  css  js  c++  java
  • 正确使用STLMAP中Erase函数

    一切尽在代码中。

    #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 ; 
    } 

    ==

  • 相关阅读:
    JSF大概介绍
    专门用于swing显示的工具类
    oracle 中查某表的所有列字段
    从实例谈OOP、工厂模式和重构
    C#中结构或类的嵌套 的方法
    怎样成为优秀的软件模型设计者
    Asp.NET编程时的几个小技巧
    在.net安装程序中部署oracle客户端全攻略
    在.NET中调用Oracle9i存储过程经验总结
    使用JNDI的一个容易忽略的错误
  • 原文地址:https://www.cnblogs.com/graphics/p/1771110.html
Copyright © 2011-2022 走看看