因为vector的插入操作可能造成记忆体重新配置,导致原有的迭代器全部失效,所以要特别注意vector的迭代器失效问题!!
迭代器失效具体原因:
因为顺序容器内存是连续分配(分配一个数组作为内存),删除一个元素导致后面所有的元素会向前移动一个位置。(删除了一个元素,该元素后面的所有元素都要挪位置,所以,iter++,已经指向的是未知内存)。
所以对vector的任何操作,一旦引起控件重新配置,指向原vector的所有迭代器就都失效了。
解决方法:用erase方法可以返回下一个有效的iterator,这样删除后iter指向的元素后,返回的是下一个元素的迭代器,这个迭代器是vector内存调整过后新的有效的迭代器。
vector<int>::iterator iter;
for (iter = vec.begin(); iter != vec.end();)
{
if (*iter == 5)
{
iter = v.erase(iter); // 该处erase处理方法
}
else
{
iter++;
}
}