Namespaces
Variants

std::forward_list<T,Allocator>:: swap

From cppreference.net

void swap ( forward_list & other ) ;
(начиная с C++11)
(до C++17)
void swap ( forward_list & other ) noexcept ( /* see below */ ) ;
(начиная с C++17)
(constexpr начиная с C++26)

Обменивает содержимое контейнера с содержимым other . Не вызывает никаких операций перемещения, копирования или обмена для отдельных элементов.

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

Если std:: allocator_traits < allocator_type > :: propagate_on_container_swap :: value равно true , то аллокаторы обмениваются с помощью неквалифицированного вызова нечленной функции swap . В противном случае они не обмениваются (и если get_allocator ( ) ! = other. get_allocator ( ) , поведение не определено).

Содержание

Параметры

other - контейнер для обмена содержимым

Исключения

(нет)

(до C++17)
noexcept спецификация:
noexcept ( std:: allocator_traits < Allocator > :: is_always_equal :: value )
(начиная с C++17)

Сложность

Константа.

Пример

#include <iostream>
#include <forward_list>
template<class Os, class Co>
Os& operator<<(Os& os, const Co& co)
{
    os << '{';
    for (const auto& i : co)
        os << ' ' << i;
    return os << " } ";
}
int main()
{
    std::forward_list<int> a1{1, 2, 3}, a2{4, 5};
    auto it1 = std::next(a1.begin());
    auto it2 = std::next(a2.begin());
    int& ref1 = a1.front();
    int& ref2 = a2.front();
    std::cout << a1 << a2 << *it1 << ' ' << *it2 << ' ' << ref1 << ' ' << ref2 << '\n';
    a1.swap(a2);
    std::cout << a1 << a2 << *it1 << ' ' << *it2 << ' ' << ref1 << ' ' << ref2 << '\n';
    // Обратите внимание, что после обмена итераторы и ссылки остаются связанными с их
    // исходными элементами, например, it1, который указывал на элемент в 'a1' со значением 2
    // всё ещё указывает на тот же элемент, хотя этот элемент был перемещён в 'a2'.
}

Вывод:

{ 1 2 3 } { 4 5 } 2 5 1 4
{ 4 5 } { 1 2 3 } 2 5 1 4

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

специализирует алгоритм std::swap
(шаблон функции)