std::swap(std::unordered_set)
来自cppreference.com
< cpp | container | unordered set
在标头 <unordered_set> 定义
|
||
template< class Key, class Hash, class KeyEqual, class Alloc > void swap( std::unordered_set<Key,Hash,KeyEqual,Alloc>& lhs, |
(C++11 起) (C++17 前) |
|
template< class Key, class Hash, class KeyEqual, class Alloc > void swap( std::unordered_set<Key,Hash,KeyEqual,Alloc>& lhs, |
(C++17 起) | |
为 std::unordered_set 特化 std::swap 算法。交换 lhs
与 rhs
的内容。调用 lhs.swap(rhs) 。
参数
lhs, rhs | - | 要交换内容的容器 |
返回值
(无)
复杂度
常数。
异常
noexcept 说明:
noexcept(noexcept(lhs.swap(rhs))) |
(C++17 起) |
注解
尽管 std::swap 对容器适配器的重载是在 C++11 引入的, C++98 中已能用 std::swap 交换容器适配器。这种 std::swap 调用通常拥有线性时间复杂度,但实现可能提供更好的复杂度。
示例
运行此代码
#include <algorithm> #include <iostream> #include <unordered_set> int main() { std::unordered_set<int> alice{1, 2, 3}; std::unordered_set<int> bob{7, 8, 9, 10}; auto print = [](const int& n) { std::cout << " " << n; }; // 打印交换前的状态 std::cout << "alice:"; std::for_each(alice.begin(), alice.end(), print); std::cout << '\n'; std::cout << "bob :"; 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 << '\n'; std::cout << "bob :"; std::for_each(bob.begin(), bob.end(), print); std::cout << '\n'; }
可能的输出:
alice: 1 2 3 bob : 7 8 9 10 -- SWAP alice: 7 8 9 10 bob : 1 2 3
参阅
(C++11) |
交换内容 (公开成员函数) |