关于vector的insert 、 erase、resize操作导致迭代器无效化

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容器是先用allocator分配定量的内存,当vector插入某个数量的元素后超出了vector的容量,此时会重新用allocator申请更大容量的内存,将原来的元素拷贝到新的内存空间中,原来的内存空间就会被释放,那么原先定义的迭代器就失效了; 希望这点解释能帮助到你。