std:: swap (std::unordered_map)
|
Definiert im Header
<unordered_map>
|
||
|
template
<
class
Key,
class
T,
class
Hash,
class
KeyEqual,
class
Alloc
>
void
swap
(
std::
unordered_map
<
Key, T, Hash, KeyEqual, Alloc
>
&
lhs,
|
(seit C++11)
(bis C++17) |
|
|
template
<
class
Key,
class
T,
class
Hash,
class
KeyEqual,
class
Alloc
>
void
swap
(
std::
unordered_map
<
Key, T, Hash, KeyEqual, Alloc
>
&
lhs,
|
(seit C++17)
(constexpr seit C++26) |
|
Spezialisiert den std::swap -Algorithmus für std::unordered_map . Tauscht die Inhalte von lhs und rhs . Ruft lhs. swap ( rhs ) auf.
Inhaltsverzeichnis |
Parameter
| lhs, rhs | - | Container, deren Inhalte ausgetauscht werden sollen |
Komplexität
Konstante.
Exceptions
|
noexcept
Spezifikation:
noexcept
(
noexcept
(
lhs.
swap
(
rhs
)
)
)
|
(seit C++17) |
Beispiel
#include <algorithm> #include <iostream> #include <unordered_map> int main() { std::unordered_map<int, char> alice{{1, 'a'}, {2, 'b'}, {3, 'c'}}; std::unordered_map<int, char> bob{{7, 'Z'}, {8, 'Y'}, {9, 'X'}, {10, 'W'}}; auto print = [](std::pair<const int, char>& n) { std::cout << ' ' << n.first << ':' << n.second; }; // Zustand vor dem Tausch ausgeben 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 << "-- SWAP\n"; std::swap(alice, bob); // Zustand nach dem Tausch ausgeben 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'; }
Mögliche Ausgabe:
Alice: 1:a 2:b 3:c Bobby: 7:Z 8:Y 9:X 10:W -- SWAP Alice: 7:Z 8:Y 9:X 10:W Bobby: 1:a 2:b 3:c
Siehe auch
|
tauscht die Inhalte aus
(öffentliche Elementfunktion) |