急问STL中的map问题

C、C++和Java语言
回复
starter2011
帖子: 1
注册时间: 2011-02-28 13:34
送出感谢: 0
接收感谢: 0

急问STL中的map问题

#1

帖子 starter2011 » 2011-02-28 13:46

网上都说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;
}
头像
BigSnake.NET
帖子: 12522
注册时间: 2006-07-02 11:16
来自: 廣州
送出感谢: 0
接收感谢: 7 次
联系:

Re: 急问STL中的map问题

#2

帖子 BigSnake.NET » 2011-03-03 21:47

能访问不代表没失效,标准说失效了就是失效了
^_^ ~~~
要理解递归,首先要理解递归。

地球人都知道,理论上,理论跟实际是没有差别的,但实际上,理论跟实际的差别是相当大滴。
hmh3186
帖子: 1
注册时间: 2011-02-26 22:04
送出感谢: 0
接收感谢: 0

Re: 急问STL中的map问题

#3

帖子 hmh3186 » 2011-03-04 22:25

同意楼上,不应该这样使用,它会导致程序无定义的行为。
回复

回到 “C/C++/Java”