std::tuple<Types...>::swap
来自cppreference.com
在标头 <tuple> 定义
|
||
(1) | ||
void swap( tuple& other ) noexcept(/* see below */); |
(C++11 起) (C++20 前) |
|
constexpr void swap( tuple& other ) noexcept(/* see below */); |
(C++20 起) | |
constexpr void swap( const tuple& other ) noexcept(/* see below */) const; |
(2) | (C++23 起) |
对 *this 中的每个元素与 other
中其对应元素调用 swap
(可以是 std::swap ,或通过 ADL 找到的)。
若任何选择的 |
(C++23 前) |
若任何选择的 |
(C++23 起) |
参数
other | - | 要交换值的 tuple
|
返回值
(无)
异常
noexcept 说明:
noexcept( noexcept(swap(std::declval<T0&>>(), std::declval<T0&>())) && 上述表达式中,以 C++17 std::is_nothrow_swappable 特性所用的相同方式查找标识符 |
(C++17 前) |
1)
noexcept 说明:
noexcept((std::is_nothrow_swappable_v<Types> && ...)) 2) noexcept 说明:
noexcept((std::is_nothrow_swappable_v<const Types> && ...)) |
(C++17 起) |
示例
运行此代码
#include <iostream> #include <string> #include <tuple> int main() { std::tuple<int, std::string, float> p1{42, "ABCD", 2.71}, p2; p2 = std::make_tuple(10, "1234", 3.14); auto print_p1_p2 = [&](auto rem) { std::cout << rem << "p1 = {" << std::get<0>(p1) << ", " << std::get<1>(p1) << ", " << std::get<2>(p1) << "}, " << "p2 = {" << std::get<0>(p2) << ", " << std::get<1>(p2) << ", " << std::get<2>(p2) << "}\n"; }; print_p1_p2("Before p1.swap(p2): "); p1.swap(p2); print_p1_p2("After p1.swap(p2): "); swap(p1, p2); print_p1_p2("After swap(p1, p2): "); }
输出:
Before p1.swap(p2): p1 = {42, ABCD, 2.71}, p2 = {10, 1234, 3.14} After p1.swap(p2): p1 = {10, 1234, 3.14}, p2 = {42, ABCD, 2.71} After swap(p1, p2): p1 = {42, ABCD, 2.71}, p2 = {10, 1234, 3.14}
缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
缺陷报告 | 应用于 | 出版时的行为 | 正确行为 |
---|---|---|---|
LWG 2456 | C++11 | noexcept 规定曾为非良构
|
使之有效 |
参阅
(C++11) |
特化 std::swap 算法 (函数模板) |
(C++11) |
交换内容 ( std::pair<T1,T2> 的公开成员函数) |