std::is_swappable_with, std::is_swappable, std::is_nothrow_swappable_with, std::is_nothrow_swappable
来自 cppreference.cn
| 定义于头文件 <type_traits> |
||
| template< class T, class U > struct is_swappable_with; |
(1) | (C++17 起) |
| template< class T > struct is_swappable; |
(2) | (C++17 起) |
| template< class T, class U > struct is_nothrow_swappable_with; |
(3) | (C++17 起) |
| template< class T > struct is_nothrow_swappable; |
(4) | (C++17 起) |
1) 如果表达式 swap(std::declval<T>(), std::declval<U>()) 和 swap(std::declval<U>(), std::declval<T>()) 在 using std::swap; 之后(参见 Swappable)在未求值上下文中均格式良好,则提供成员常量
value 等于 true。否则,value 为 false。 访问检查 执行时如同来自与两种类型均无关的上下文。
3) 与 (1) 相同,但 (1) 中两个表达式的求值已知不抛出异常。
| 类型特征 | 成员常量 value 的值 | |
|---|---|---|
T 是可引用类型 |
T 不是可引用类型 | |
| (2) | std::is_swappable_with<T&, T&>::value | false |
| (4) | std::is_nothrow_swappable_with<T&, T&>::value | |
如果 T 或 U 不是完整类型、(可能带 cv 限定的)void,或未知边界的数组,则行为未定义。
如果上述模板的实例化直接或间接依赖于不完整类型,并且该实例化在该类型假设完成时可能产生不同的结果,则行为未定义。
如果程序为此页上描述的任何模板添加特化,则行为未定义。
目录 |
[编辑] 辅助变量模板
| template< class T, class U > inline constexpr bool is_swappable_with_v = is_swappable_with<T, U>::value; |
(C++17 起) | |
| template< class T > inline constexpr bool is_swappable_v = is_swappable<T>::value; |
(C++17 起) | |
| template< class T, class U > inline constexpr bool is_nothrow_swappable_with_v = |
(C++17 起) | |
| template< class T > inline constexpr bool is_nothrow_swappable_v = |
(C++17 起) | |
继承自 std::integral_constant
成员常量
| value [静态] |
如果 T 可以与 U 交换,则为 true,否则为 false(public static 成员常量) |
成员函数
| operator bool |
将对象转换为 bool,返回 value (公开成员函数) |
| operator() (C++14) |
返回 value (公开成员函数) |
成员类型
| 类型 | 定义 |
value_type
|
bool |
类型
|
std::integral_constant<bool, value> |
[编辑] 注解
此特性不检查交换表达式的直接上下文之外的任何内容:如果 T 或 U 的使用会触发模板特化、隐式定义特殊成员函数的生成等,并且这些存在错误,即使 std::is_swappable_with<T, U>::value 编译并评估为 true,实际的交换也可能无法编译。
[编辑] 示例
| 本节不完整 原因:无示例 |
[编辑] 另请参阅
| 交换两个对象的值 (函数模板) | |
| (C++11)(C++11)(C++11) |
检查类型是否有移动赋值运算符 (类模板) |
| (C++20) |
指定类型可以被交换,或者两种类型可以互相交换 (概念) |