std::deque<T,Allocator>::erase

Erases the specified elements from the container.

# Declarations

iterator erase( iterator pos );

(until C++11)

iterator erase( const_iterator pos );

(since C++11)

iterator erase( iterator first, iterator last );

(until C++11)

iterator erase( const_iterator first, const_iterator last );

(since C++11)

# Parameters

# Return value

Iterator following the last removed element.

# Notes

When container elements need to be erased based on a predicate, rather than iterating the container and calling unary erase, the iterator range overload is generally used with std::remove()/std::remove_if() to minimise the number of moves of the remaining (non-removed) elements, — this is the erase-remove idiom. std::erase_if() replaces the erase-remove idiom.(since C++20)

# Example

#include <deque>
#include <iostream>
 
 
void print_container(const std::deque<int>& c)
{
    for (int i : c)
        std::cout << i << ' ';
    std::cout << '\n';
}
 
int main()
{
    std::deque<int> c{0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
    print_container(c);
 
    c.erase(c.begin());
    print_container(c);
 
    c.erase(c.begin() + 2, c.begin() + 5);
    print_container(c);
 
    // Erase all even numbers
    for (std::deque<int>::iterator it = c.begin(); it != c.end();)
    {
        if (*it % 2 == 0)
            it = c.erase(it);
        else
            ++it;
    }
    print_container(c);
}

# Defect reports

DRApplied toBehavior as publishedCorrect behavior
LWG 151C++98first was required to be dereferenceable, whichmade the behavior of clearing an empty deque undefinednot required iffirst == last
LWG 638C++98the past-the-end iterator was not invalidatedit is invalidated if the elements areerased from the middle or the end

# See also