Namespaces
Variants

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

From cppreference.net

(1)
iterator erase ( iterator pos ) ;
(до C++11)
iterator erase ( const_iterator pos ) ;
(начиная с C++11)
(constexpr начиная с C++26)
(2)
iterator erase ( iterator first, iterator last ) ;
(до C++11)
iterator erase ( const_iterator first, const_iterator last ) ;
(начиная с C++11)
(constexpr начиная с C++26)

Удаляет указанные элементы из контейнера.

1) Удаляет элемент в позиции pos .
2) Удаляет элементы в диапазоне [ first , last ) .

Все итераторы и ссылки становятся недействительными, за исключением случаев, когда удаляемые элементы находятся в конце или в начале контейнера — в этом случае недействительными становятся только итераторы и ссылки на удалённые элементы. end() итератор также становится недействительным, если удаляемые элементы находятся не в начале контейнера или если последний элемент удаляется.

Итератор pos должен быть действительным и разыменуемым. Следовательно, итератор end() (который является действительным, но не может быть разыменован) не может использоваться в качестве значения для pos .

Итератор first не обязательно должен быть разыменовываемым, если first == last : удаление пустого диапазона является операцией без эффекта.

Содержание

Параметры

pos - итератор на удаляемый элемент
first, last - пара итераторов, определяющих диапазон удаляемых элементов
Требования к типу
-
Если T не является MoveAssignable , поведение не определено.

Возвращаемое значение

Итератор, следующий за последним удалённым элементом.

1) Если pos указывает на последний элемент, то возвращается итератор end() .
2) Если last == end ( ) до удаления, то возвращается обновленный итератор end() .
Если [ first , last ) является пустым диапазоном, то возвращается last .

Исключения

Не вызывает исключений, если только исключение не вызвано оператором присваивания T .

Сложность

Линейная: количество вызовов деструктора T равно количеству удаленных элементов, количество вызовов оператора присваивания T не превышает меньшего из количества элементов до удаленных элементов и количества элементов после удаленных элементов.

Примечания

Когда элементы контейнера нужно удалить на основе предиката, вместо итерации по контейнеру и вызова унарного erase , обычно используется перегрузка с диапазоном итераторов вместе с std::remove()/std::remove_if() для минимизации количества перемещений оставшихся (неудаленных) элементов — это идиома erase-remove. std::erase_if() заменяет идиому erase-remove. (since C++20)

Пример

#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);
    // Удалить все четные числа
    for (std::deque<int>::iterator it = c.begin(); it != c.end();)
    {
        if (*it % 2 == 0)
            it = c.erase(it);
        else
            ++it;
    }
    print_container(c);
}

Вывод:

0 1 2 3 4 5 6 7 8 9
1 2 3 4 5 6 7 8 9
1 2 6 7 8 9
1 7 9

Отчеты о дефектах

Следующие отчеты об изменениях поведения, влияющие на дефекты, были применены ретроактивно к ранее опубликованным стандартам C++.

DR Applied to Behavior as published Correct behavior
LWG 151 C++98 first требовалось быть разыменуемым, что
делало поведение очистки пустого deque неопределенным
не требуется, если
first == last
LWG 638 C++98 итератор за последним элементом не инвалидировался он инвалидируется, если элементы
удаляются из середины или конца

Смотрите также

удаляет все элементы, удовлетворяющие определенным критериям
(шаблон функции)
очищает содержимое
(публичная функция-член)