There are a few issues with your code above. Firstly, the remove
will invalidate any iterators that are pointing at the removed elements. You then go on to continue using the iterator. It is difficult to tell which element(s) remove
would erase in the general case (although not in yours) since it can remove more than one.
Secondly, you are probably using the wrong method. Remove will iterate through all of the items in the list looking for any matching elements - this will be inefficient in your case because there is only one. It looks like you should use the erase
method, you probably only want to erase the item at the position of the iterator. The good thing about erase
is it returns an iterator which is at the next valid position. The idiomatic way to use it is something like this:
//remove even numbers
for(itr = listA.begin(); itr != listA.end();)
{
if ( *itr % 2 == 0 )
{
cout << *itr << endl;
itr=listA.erase(itr);
}
else
++itr;
}
Finally, you could also use remove_if
to do the same as you are doing:
bool even(int i) { return i % 2 == 0; }
listA.remove_if(even);
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…