在C++primer中写明,erase()会返回一个迭代器,指向的是被删除元素的下一个位置,指向当前被删除元素位置的迭代器会失效。
所以在遍历或者循环vector中删除元素时,需要注意迭代器的变化。
下面自己写了几个测试代码,搞清楚几个错误。
1. 看到有帖子说,erase(iter) 后, iter会自动指向下一个位置,还说出了原理,看似可信。
自己试了一下,却是不行的,iter并不会自动指向下一个位置。在删除元素后,vector的size会自动变化。
using namespace std;
int main()
{
vector<int> test;
vector<int>::iterator iter;
for(int i = 0; i < 10;i++)
{
test.push_back(i);
}
cout<<"before eresing size is "<<test.size()<<endl;
iter = test.begin();
while(iter != test.end())
{
if((*iter) == 2)
{
//test.erase(iter);//这样写,编译可以通过,运行时,程序会崩溃
//test.erase(iter++);//也不行
//test.erase(++iter);//也不行
iter = test.erase(iter);//这样才可以
}
else
iter++;
}
cout<<"after eresing size is "<<test.size()<<endl;
return 0;
}