Namespaces
Variants

std::vector<bool,Allocator>:: swap

From cppreference.net
Défini dans l'en-tête <vector>
static void swap ( reference x, reference y ) ;
(constexpr depuis C++20)

Échange le contenu de x et y comme si par bool b = x ; x = y ; y = b ; .

Table des matières

Paramètres

x - std::vector < bool > :: reference valeur à échanger avec y
y - std::vector < bool > :: reference valeur à échanger avec x

Valeur de retour

(aucun)

Complexité

Constante.

Exemple

#include <iostream>
#include <vector>
void println(std::string_view fmt, std::vector<bool> const& vb = {})
{
    for (std::cout << fmt; bool const e : vb)
        std::cout << e << ' ';
    std::cout << '\n';
}
int main()
{
    println("swap elements of the same vector:");
    std::vector<bool> x{1, 0};
    println("before swap, x: ", x);
    x.swap(x[0], x[1]); // same as std::vector<bool>::swap(x[0], x[1]);
    println("after swap,  x: ", x);
    println("swap elements of two different vectors:");
    std::vector<bool> y{0, 0, 1};
    println("before swap, x: ", x);
    println("before swap, y: ", y);
    y.swap(x[0], y[2]); // same as std::vector<bool>::swap(x[0], y[2]);
    println("after swap,  x: ", x);
    println("after swap,  y: ", y);
}

Sortie :

swap elements of the same vector:
before swap, x: 1 0 
after swap,  x: 0 1 
swap elements of two different vectors:
before swap, x: 0 1 
before swap, y: 0 0 1 
after swap,  x: 1 1 
after swap,  y: 0 0 0

Rapports de défauts

Les rapports de défauts modifiant le comportement suivants ont été appliqués rétroactivement aux normes C++ précédemment publiées.

DR Appliqué à Comportement tel que publié Comportement correct
LWG 814 C++98 la description de cette fonction membre était manquante ajoutée

Voir aussi

classe proxy représentant une référence à un seul bool
(classe)
échange le contenu
(fonction membre publique de std::vector<T,Allocator> )
spécialise l'algorithme std::swap
(fonction template)