Namespaces
Variants

std:: swap (std::forward_list)

From cppreference.net

Défini dans l'en-tête <forward_list>
template < class T, class Alloc >

void swap ( std:: forward_list < T, Alloc > & lhs,

std:: forward_list < T, Alloc > & rhs ) ;
(depuis C++11)
(jusqu'à C++17)
template < class T, class Alloc >

void swap ( std:: forward_list < T, Alloc > & lhs,
std:: forward_list < T, Alloc > & rhs )

noexcept ( /* voir ci-dessous */ ) ;
(depuis C++17)
(constexpr depuis C++26)

Spécialise l'algorithme std::swap pour std::forward_list . Échange le contenu de lhs et rhs . Appelle lhs. swap ( rhs ) .

Table des matières

Paramètres

lhs, rhs - conteneurs dont le contenu doit être échangé

Complexité

Constante.

Exceptions

noexcept spécification :
noexcept ( noexcept ( lhs. swap ( rhs ) ) )
(depuis C++17)

Exemple

#include <algorithm>
#include <iostream>
#include <forward_list>
int main()
{
    std::forward_list<int> alice{1, 2, 3};
    std::forward_list<int> bob{7, 8, 9, 10};
    auto print = [](const int& n) { std::cout << ' ' << n; };
    // État avant l'échange
    std::cout << "Alice:";
    std::for_each(alice.begin(), alice.end(), print);
    std::cout << "\nBobby:";
    std::for_each(bob.begin(), bob.end(), print);
    std::cout << '\n';
    std::cout << "-- ÉCHANGE\n";
    std::swap(alice, bob);
    // État après l'échange
    std::cout << "Alice:";
    std::for_each(alice.begin(), alice.end(), print);
    std::cout << "\nBobby:";
    std::for_each(bob.begin(), bob.end(), print);
    std::cout << '\n';
}

Sortie :

Alice: 1 2 3
Bobby: 7 8 9 10
-- ÉCHANGE
Alice: 7 8 9 10
Bobby: 1 2 3

Voir aussi

échange le contenu
(fonction membre publique)