std::swap(std::multiset)
来自cppreference.com
容器库
std::multiset
成员函数 | ||||
迭代器 | ||||
(C++11)
|
||||
(C++11)
|
||||
(C++11)
|
||||
容量 | ||||
修改器 | ||||
(C++11)
|
||||
(C++11)
|
||||
(C++17)
|
||||
(C++17)
|
||||
查找 | ||||
(C++20)
|
||||
观察器 | ||||
非成员函数 | ||||
std::swap
|
||||
(C++20)
|
||||
(C++20
前)(C++20
前)(C++20
前)(C++20
前)(C++20
前)(C++20)
|
||||
推导指引(C++17) |
在标头
<set>
定义
|
||
template< class Key, class Compare, class Alloc
>
void swap( std::multiset<Key, Compare, Alloc>& lhs, |
(C++17 前) | |
template< class Key, class Compare, class Alloc
>
void swap( std::multiset<Key, Compare, Alloc>& lhs, |
(C++17 起) | |
为 std::multiset
特化 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 <set> int main() { std::multiset<int> alice{1, 2, 3}; std::multiset<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
参阅
交换内容 (公开成员函数) |