Last updated
Last updated
When using iterators, we need to pay attention to the validation of them. In some cases, the iterator may turns invalid, which is not easy to notice.
For example, in the following case, we use an iterator to delete all the even numbers in the vector.
But the program exits abnormally. In fact, after the first element is erased from the vector, the elements after it need to be moved forward. Therefore, all iterators behind the current one is no longer valid any more.
The second example is to add n - 1 before every even number n:
Similarly, an error occurs after the first element is added. When an element is added, all elements after it need to be moved backward, so their iterators are invalid. Moreover, the vector is likely to be double-expanded, in which all iterators of the container are invalid now.
If an iterator is invalid, we can no longer do iterator operations, for example increment and dereference. To fix this, we need to update the iterator at the erase point or insert point. The designers of STL containers have taken this into account, so function erase() and insert() return a new iterator pointing to the current element after called.
After an element is erased from the container, the elements after it will move forward, and the returned iterator points to the one after the erase point, so increment is not needed when an element is erased.
After an element is erased from the container, the elements after it will move backward, and the returned iterator points to the one being added, so another increment is needed in this case.
How does the iterator invalidation works at the bottom? In STL containers, a linked list is used to maintain the status of current iterators. Every time a container operation is performed, the validation of current iterator is verified using the linked list. We will not elaborate here, but we modify our MyVector class to implement this feature.