当前时区为 UTC + 8 小时



发表新帖 回复这个主题  [ 3 篇帖子 ] 
作者 内容
1 楼 
 文章标题 : 急问STL中的map问题
帖子发表于 : 2011-02-28 13:46 

注册: 2011-02-28 13:34
帖子: 1
送出感谢: 0 次
接收感谢: 0 次
网上都说map的erase函数调用后,iterator就失效了。而且win下erase和linux下erase的区别就是win下得有返回值返回下一个位置的iterator,而linux下无返回值而已。
可是我现在在ubuntu下调用map的erase函数后,iterator却没有失效,erase后还可以访问原来指向的数据。但是循环结束后重新遍历时,又都删除掉了。请问这是怎么一回事呀? 我是用g++编译得,谢谢各位解答了。
代码:
#include <iostream>
#include <map>
#include <iterator>

using namespace std;

int main()
{
    map<int, char> testlist;
    testlist.insert(make_pair(1, 'a'));
    testlist.insert(make_pair(2, 'b'));
    testlist.insert(make_pair(3, 'c'));
    testlist.insert(make_pair(4, 'd'));

    map<int, char>::iterator iter;
    for(iter = testlist.begin(); iter != testlist.end(); iter++)
    {
        cout<<"list:"<<iter->first<<":"<<iter->second<<endl;
        testlist.erase(iter);
        cout<<"again:"<<iter->first<<":"<<iter->second<<endl;
    }
    for(iter = testlist.begin(); iter != testlist.end(); iter++)
    {
        cout<<"list:"<<iter->first<<":"<<iter->second<<endl;
        testlist.erase(iter);
        cout<<"again:"<<iter->first<<":"<<iter->second<<endl;
    }

    return 0;
}


页首
 用户资料  
 
2 楼 
 文章标题 : Re: 急问STL中的map问题
帖子发表于 : 2011-03-03 21:47 
头像

注册: 2006-07-02 11:16
帖子: 12522
地址: 廣州
送出感谢: 0 次
接收感谢: 8
能访问不代表没失效,标准说失效了就是失效了


_________________
^_^ ~~~
要理解递归,首先要理解递归。

地球人都知道,理论上,理论跟实际是没有差别的,但实际上,理论跟实际的差别是相当大滴。


页首
 用户资料  
 
3 楼 
 文章标题 : Re: 急问STL中的map问题
帖子发表于 : 2011-03-04 22:25 

注册: 2011-02-26 22:04
帖子: 1
送出感谢: 0 次
接收感谢: 0 次
同意楼上,不应该这样使用,它会导致程序无定义的行为。


页首
 用户资料  
 
显示帖子 :  排序  
发表新帖 回复这个主题  [ 3 篇帖子 ] 

当前时区为 UTC + 8 小时


在线用户

正在浏览此版面的用户:没有注册用户 和 1 位游客


不能 在这个版面发表主题
不能 在这个版面回复主题
不能 在这个版面编辑帖子
不能 在这个版面删除帖子
不能 在这个版面提交附件

前往 :  
本站点为公益性站点,用于推广开源自由软件,由 DiaHosting VPSBudgetVM VPS 提供服务。
我们认为:软件应可免费取得,软件工具在各种语言环境下皆可使用,且不会有任何功能上的差异;
人们应有定制和修改软件的自由,且方式不受限制,只要他们自认为合适。

Powered by phpBB © 2000, 2002, 2005, 2007 phpBB Group
简体中文语系由 王笑宇 翻译