Namespaces
Variants

std::list<T,Allocator>:: pop_back

From cppreference.net

void pop_back ( ) ;
(constexpr начиная с C++26)

Удаляет последний элемент контейнера.

Если empty() возвращает true , поведение не определено.

(до C++26)

Если empty() возвращает true :

  • Если реализация является защищённой , происходит нарушение контракта . Более того, если обработчик нарушения контракта возвращает управление при семантике оценки "observe", поведение не определено.
  • Если реализация не является защищённой, поведение не определено.
(начиная с C++26)

Ссылки и итераторы на удалённый элемент становятся недействительными.

Сложность

Константа.

Пример

#include <list>
#include <iostream>
namespace stq
{
    template<typename T>
    void println(auto, const T& xz)
    {
        std::cout << '[';
        bool first{true};
        for (const auto& x : xz)
            std::cout << (first ? first = false, "" : ", ") << x;
        std::cout << "]\n";
    }
}
int main()
{
    std::list<int> numbers{1, 2, 3};
    stq::println("{}", numbers);
    while (not numbers.empty())
    {
        numbers.pop_back();
        stq::println("{}", numbers);
    }
}

Вывод:

[1, 2, 3]
[1, 2]
[1]
[]

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

удаляет первый элемент
(public member function)
добавляет элемент в конец
(public member function)