//今天在写程序的时候意外出现了下面这种情况,搞得我一时之间没有找到原因,很郁闷。
#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;
}