#
# vector
# 20060629 by daineng@nj.cpsecure
#
vector::erase(iterator) 的返回值代表什么,这个操作是否可能引起内存泄露
# 无论是调用前保存iterator还是接受调用后的返回之,这个iterator
# 指向的是这个位置上的对象,也是调用前iterator的下一个对象
#
# 调用前iterator指向的对象被丢失,在程序结束时也没有析构
#
# 但调用erase之前delete iterator会引起错误,iterator并不是指针,虽然
# 在某些版本的实作中被定义为指针
# erase()内部使用copy()来移动空出的slot,这实际上是一个memcpy,
# iterator指向的位置上的内容被覆盖,这就是无论引用、指针、迭代子
# 都指向/是调用前iterator后面的那个对象的原因
#
# 因为覆盖,所以被覆盖的对象没有调用析构函数
#
# 如果是一个复杂的对象,new了一块内存,很明显这样的操作会引起
# 内存泄漏
#
# 解决方法是在erase之前把对象拷贝出来(拷贝必须是浅拷贝),借着
# 拷贝出的对象的析构完成所有内存的释放
# 举一个实际的例子,如果vector中保存的是new出来的指针,那么erase
# 之前需要做delete
delete vec[i] ; // vector <int*> vec
vec.erase(vec.begin() + i) ;