现在的位置: 首页 > 综合 > 正文

关于stl map,要注意erase的用法

2017年01月22日 ⁄ 综合 ⁄ 共 839字 ⁄ 字号 评论关闭

//今天在写程序的时候意外出现了下面这种情况,搞得我一时之间没有找到原因,很郁闷。

#include <iostream>

using namespace std;
#include <map>
#include <string>

int main()
{
        map<int,string> ms;
        ms.insert(make_pair(1,"huzhongsan"));
        int i=2;
        while(i--)
        {
                map<int,string>::iterator it = ms.find(i);//在这里,当i的值为0时,没有找到,会返回ms.end()
                ms.erase(it);//如果it为ms.end() ,在这里就会出现意外,在这里会阻塞,阻的死死的,程序就会停在这里。
        }
        return 0;
}

如何避免上面这种情况呢,这好办,加个判断就好,注意,这种情况一旦出现,如果你写的是一个很大的程序,有可能不好一下子将这bug揪出来,

而且我们好多人(比如像我这样的菜鸟),现在对stl map的内部实现不是很清楚,遇到这种错误,很难解释,只有通过猜测,然后编程验证,有些

时候真的是没有什么道理可讲,呵呵

下面给出一种避免上述情况发生的方法

#include <iostream>
using namespace std;
#include <map>
#include <string>

int main()
{
        map<int,string> ms;
        ms.insert(make_pair(1,"huzhongsan"));
        int i=2;
        while(i--)
        {
                map<int,string>::iterator it = ms.find(i);
                if(it!=ms.end()) //就是这样,加个判断就OK了!!!
                        ms.erase(it);
        }
        return 0;
}

抱歉!评论已关闭.