STL的map问题 ,谁能告诉我这段代码哪里有问题

map<int,CFriend*>::iteratorite=m_map_groupfriend.begin();for(;ite!=m_map_groupfriend.... map<int,CFriend*>::iterator ite = m_map_groupfriend.begin();
for(;ite != m_map_groupfriend.end();ite++)
{
CFriend* findFriend = ite->second;

delete findFriend;
m_map_groupfriend.erase(ite);
}
展开
 我来答
志远823
2011-09-15 · TA获得超过2296个赞
知道小有建树答主
回答量:913
采纳率:66%
帮助的人:1183万
展开全部
删除的时候不能这么干,有两种方法供你参考
方法1

TestMap::iterator it;

for (it = mapTest.begin(); it != mapTest.end() && !mapTest.isEmpty(); ++ it)

{

mapTest.erase(it);

}

删除后原有的迭代器在判断是否end的时候会失败,一定要注意

方法2(推荐)

std::map<int,string> a;

a.insert(make_pair(1,string("1")));

a.insert(make_pair(2,string("2")));

a.insert(make_pair(3,string("3")));

a.insert(make_pair(4,string("4")));

std::map<int,string>::iterator it=a.begin();

while(it!=a.end())

{

cout<<it->first<<":"<<it->second<<endl;

a.erase(it++); //使用删除之前的迭代器定位下一个元素

}
dino_fighter
2011-09-15
知道答主
回答量:2
采纳率:0%
帮助的人:3.1万
展开全部
在进行会改变map的操作时迭代器要慎用,不熟悉的话在改变操作后不知道迭代器会指向哪里。erase操作之后ite++指向的不是你希望的地方,具体指向哪我也不清楚,可以试试楼上的方法是否可行。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式