Namespaces
Variants

std:: swap (std::queue)

From cppreference.net

Definido en el encabezado <queue>
template < class T, class Container >

void swap ( std:: queue < T, Container > & lhs,

std:: queue < T, Container > & rhs ) ;
(desde C++11)
(hasta C++17)
template < class T, class Container >

void swap ( std:: queue < T, Container > & lhs,
std:: queue < T, Container > & rhs )

noexcept ( /* ver más abajo */ ) ;
(desde C++17)
(constexpr desde C++26)
Specializes the std::swap algorithm for std::queue . Swaps the contents of lhs and rhs . Calls lhs. swap ( rhs ) .

Esta sobrecarga participa en la resolución de sobrecarga solo si std:: is_swappable_v < Container > es true .

(since C++17)

Contenidos

Parámetros

lhs, rhs - contenedores cuyos contenidos intercambiar

Complejidad

Igual que intercambiar los contenedores subyacentes.

Excepciones

noexcept especificación:
noexcept ( noexcept ( lhs. swap ( rhs ) ) )
(desde C++17)

Notas

Aunque las sobrecargas de std::swap para adaptadores de contenedor se introdujeron en C++11, los adaptadores de contenedor ya podían intercambiarse mediante std::swap en C++98. Dichas llamadas a std::swap normalmente tienen complejidad temporal lineal, pero podría proporcionarse una complejidad mejor.

Ejemplo

#include <algorithm>
#include <iostream>
#include <queue>
int main()
{
    std::queue<int> alice;
    std::queue<int> bob;
    auto print = [](const auto& title, const auto& cont)
    {
        std::cout << title << " size=" << cont.size();
        std::cout << " front=" << cont.front();
        std::cout << " back=" << cont.back() << '\n';
    };
    for (int i = 1; i < 4; ++i)
        alice.push(i);
    for (int i = 7; i < 11; ++i)
        bob.push(i);
    // Imprimir estado antes del intercambio
    print("Alice:", alice);
    print("Bobby:", bob);
    std::cout << "-- INTERCAMBIO\n";
    std::swap(alice, bob);
    // Imprimir estado después del intercambio
    print("Alice:", alice);
    print("Bobby:", bob);
}

Salida:

Alice: size=3 front=1 back=3
Bobby: size=4 front=7 back=10
-- INTERCAMBIO
Alice: size=4 front=7 back=10
Bobby: size=3 front=1 back=3

Véase también

(C++11)
intercambia los contenidos
(función miembro pública)