免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1230 | 回复: 2
打印 上一主题 下一主题

[C++] 从关联容器里面删除元素,程序崩溃了 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-12-15 10:24 |只看该作者 |倒序浏览

  1. #include<map>
  2. using namespace std;
  3. class M{};
  4. int main()
  5. {
  6.     map<size_t, M> m;
  7.     m.insert(make_pair(2, M()));
  8.     m.insert(make_pair(1, M()));
  9.     m.insert(make_pair(0, M()));
  10.     for (pair<const size_t, M>& p : m)
  11.         cout<<p.first<<',';
  12.     m.erase(m.find(2), m.find(1));//崩溃在这里
  13.     cout<<m.size()<<endl;
  14.     return 0;
  15. }
复制代码
发现map::erase的调用,似乎first iterator和last iterator的key,大小要按照map::comp函数的<关系来放,不然就崩溃?

不知道C++语言标准对此有没有规定,还是现在流行的STL实现都会在这里崩溃呢?
谢谢。

论坛徽章:
324
射手座
日期:2013-08-23 12:04:38射手座
日期:2013-08-23 16:18:12未羊
日期:2013-08-30 14:33:15水瓶座
日期:2013-09-02 16:44:31摩羯座
日期:2013-09-25 09:33:52双子座
日期:2013-09-26 12:21:10金牛座
日期:2013-10-14 09:08:49申猴
日期:2013-10-16 13:09:43子鼠
日期:2013-10-17 23:23:19射手座
日期:2013-10-18 13:00:27金牛座
日期:2013-10-18 15:47:57午马
日期:2013-10-18 21:43:38
2 [报告]
发表于 2015-12-15 10:28 |只看该作者
这样不是一个有效的范围了,结果未定义

论坛徽章:
14
巨蟹座
日期:2013-11-19 14:09:4615-16赛季CBA联赛之青岛
日期:2016-07-05 12:36:0515-16赛季CBA联赛之广东
日期:2016-06-29 11:45:542015亚冠之全北现代
日期:2015-07-22 08:09:472015年辞旧岁徽章
日期:2015-03-03 16:54:15巨蟹座
日期:2014-12-29 08:22:29射手座
日期:2014-12-05 08:20:39狮子座
日期:2014-11-05 12:33:52寅虎
日期:2014-08-13 09:01:31巳蛇
日期:2014-06-16 16:29:52技术图书徽章
日期:2014-04-15 08:44:01天蝎座
日期:2014-03-11 13:06:45
3 [报告]
发表于 2015-12-15 11:14 |只看该作者
顶楼上
[a,b) 和 [b,a) 这两个范围是不一样的
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP