std::experimental::optional<T>::swap
来自 cppreference.cn
< cpp | experimental | optional
void swap( optional& other ) noexcept(/* 见下文 */); |
(库基础 TS) | |
交换与 other 的内容。
- 如果 *this 和 other 均不含值,则函数无效果。
- 如果 *this 和 other 中只有一个含值(我们称该对象为
in
,另一个为un
),则un
的含值通过 std::move(*in) 直接初始化,随后销毁in
的含值,如同通过 in.val->T::~T()。此调用后,in
不含值,un
含值。
- 如果 *this 和 other 都含值,则通过调用 using std::swap; swap(**this, *other) 交换含值。
T
左值必须满足 可交换 (Swappable)。
目录 |
[编辑] 参数
其他 | - | 用于交换内容的 optional 对象 |
[编辑] 返回值
(无)
[编辑] 异常
noexcept 规范:
noexcept(std::is_nothrow_move_constructible<T>::value &&
noexcept(swap(std::declval<T&>(), std::declval<T&>())))
noexcept(swap(std::declval<T&>(), std::declval<T&>())))
如果抛出异常,*this 和 other 的含值状态由类型 T
的 swap
或 T
的移动构造函数的异常安全保证决定,取决于哪个被调用。对于 *this 和 other,如果对象原来含有值,则仍然含有值,反之亦然。
[编辑] 参阅
特化 std::swap 算法 (函数) |