unordered_multimap::swap
Échange le contenu de deux conteneurs.
void swap(unordered_multimap& right);
Paramètres
- right
Le conteneur à échanger avec.
Notes
La fonction membre permute les séquences contrôlées entre *this et right.Si unordered_multimap::get_allocator() == right.get_allocator(), il le fait dans le temps fixe, il lève une exception uniquement à la suite de copier l'objet Ctraits stocké du type Tr, et il n'invalide pas de référence, pointeur, ou itérateurs qui indiquent des éléments des deux séquences contrôlées.Sinon, il exécute plusieurs assignations d'élément et le constructeur appelle proportionnel au nombre d'éléments des deux séquences contrôlées.
Exemple
// std_tr1__unordered_map__unordered_multimap_swap.cpp
// compile with: /EHsc
#include <unordered_map>
#include <iostream>
typedef std::unordered_multimap<char, int> Mymap;
int main()
{
Mymap c1;
c1.insert(Mymap::value_type('a', 1));
c1.insert(Mymap::value_type('b', 2));
c1.insert(Mymap::value_type('c', 3));
// display contents " [c 3] [b 2] [a 1]"
for (Mymap::const_iterator it = c1.begin();
it != c1.end(); ++it)
std::cout << " [" << it->first << ", " << it->second << "]";
std::cout << std::endl;
Mymap c2;
c2.insert(Mymap::value_type('d', 4));
c2.insert(Mymap::value_type('e', 5));
c2.insert(Mymap::value_type('f', 6));
c1.swap(c2);
// display contents " [f 6] [e 5] [d 4]"
for (Mymap::const_iterator it = c1.begin();
it != c1.end(); ++it)
std::cout << " [" << it->first << ", " << it->second << "]";
std::cout << std::endl;
swap(c1, c2);
// display contents " [c 3] [b 2] [a 1]"
for (Mymap::const_iterator it = c1.begin();
it != c1.end(); ++it)
std::cout << " [" << it->first << ", " << it->second << "]";
std::cout << std::endl;
return (0);
}
Configuration requise
en-tête : <unordered_map>
l'espace de noms : type
Voir aussi
Référence
swap Function (unordered_multimap)