typedef vectorint_vec;
int_vec v(2,0);
int_vec::iterator iter_b = v.begin();
v.insert(v.begin(),1);
cout<<*iter_b<<endl;
//这种操作会导致iter_b无效,输出随机值
但是:
int_vec v1(2,0);
int_vec::iterator iter_b = v.begin();
v.erase(v.begin());
cout<<*iter_b<<endl;
//却能正常输出当前vector内的第一个元素,求解释
同时:
如果insert和erase依次进行操作,事先初始化的迭代器也不会被无效化,求解释
关于vector的insert 、 erase、resize操作导致迭代器无效化
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
1条回答 默认 最新
UPingX 2014-11-18 13:46关注vector容器是先用allocator分配定量的内存,当vector插入某个数量的元素后超出了vector的容量,此时会重新用allocator申请更大容量的内存,将原来的元素拷贝到新的内存空间中,原来的内存空间就会被释放,那么原先定义的迭代器就失效了; 希望这点解释能帮助到你。
评论 打赏 举报解决 2无用