std:: swap (std::unordered_map)
|
定義先ヘッダ
<unordered_map>
|
||
|
template
<
class
Key,
class
T,
class
Hash,
class
KeyEqual,
class
Alloc
>
void
swap
(
std::
unordered_map
<
Key, T, Hash, KeyEqual, Alloc
>
&
lhs,
|
(C++11以降)
(C++17まで) |
|
|
template
<
class
Key,
class
T,
class
Hash,
class
KeyEqual,
class
Alloc
>
void
swap
(
std::
unordered_map
<
Key, T, Hash, KeyEqual, Alloc
>
&
lhs,
|
(C++17以降)
(constexpr C++26以降) |
|
std::swap アルゴリズムを std::unordered_map に対して特殊化します。 lhs と rhs の内容を交換します。 lhs. swap ( rhs ) を呼び出します。
目次 |
パラメータ
| lhs, rhs | - | 内容を交換するコンテナ |
計算量
定数。
例外
|
noexcept
仕様:
noexcept
(
noexcept
(
lhs.
swap
(
rhs
)
)
)
|
(C++17以降) |
例
#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; }; // スワップ前の状態を表示 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); // スワップ後の状態を表示 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'; }
出力例:
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
関連項目
|
内容を交換する
(公開メンバ関数) |