Partilhar via


unordered_set::swap

Troca o Sumário de dois recipientes.

void swap(unordered_set& right);

Parâmetros

  • right
    O contêiner para troca.

Comentários

A função de membro troca as seqüências controladas entre *this e right. If unordered_set::get_allocator() == right.get_allocator(), ele faz, de forma in-time constante, ele lança uma exceção apenas sistema autônomo resultado de copiar o objeto de características armazenado do tipo Tr, e ele invalida sem referências, ponteiros ou iteradores designar elementos sistema autônomo duas seqüências controlados. Caso contrário, ele executa uma série de atribuições de elemento e chamadas de construtor proporcionais ao número de elementos nas duas seqüências controladas.

Exemplo

 

// std_tr1__unordered_set__unordered_set_swap.cpp 
// compile with: /EHsc 
#include <unordered_set> 
#include <iostream> 
 
typedef std::tr1::unordered_set<char> Myset; 
int main() 
    { 
    Myset c1; 
 
    c1.insert('a'); 
    c1.insert('b'); 
    c1.insert('c'); 
 
// display contents " [c] [b] [a]" 
    for (Myset::const_iterator it = c1.begin(); 
        it != c1.end(); ++it) 
        std::cout << " [" << *it << "]"; 
    std::cout << std::endl; 
 
    Myset c2; 
 
    c2.insert('d'); 
    c2.insert('e'); 
    c2.insert('f'); 
 
    c1.swap(c2); 
 
// display contents " [f] [e] [d]" 
    for (Myset::const_iterator it = c1.begin(); 
        it != c1.end(); ++it) 
        std::cout << " [" << *it << "]"; 
    std::cout << std::endl; 
 
    swap(c1, c2); 
 
// display contents " [c] [b] [a]" 
    for (Myset::const_iterator it = c1.begin(); 
        it != c1.end(); ++it) 
        std::cout << " [" << *it << "]"; 
    std::cout << std::endl; 
 
    return (0); 
    } 
 
 [c] [b] [a]  [f] [e] [d]  [c] [b] [a]

Requisitos

Cabeçalho:<unordered_set>

Namespace: std::tr1

Consulte também

Referência

<unordered_set>

Classe unordered_set

Troque a função (unordered_set)