std::is_swappable_with,std::is_swappable,std::is_nothrow_swappable_with,std::is_nothrow_swappable
来自 cppreference.com
在头文件中定义 <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; 后(见 可交换的)在未评估的上下文中都格式良好,则提供等于 true 的成员常量
value
。否则,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 [静态] |
true 如果 T 可与 U 交换,否则为 false(公共静态成员常量) |
成员函数
operator bool |
将对象转换为 bool,返回 value (公共成员函数) |
operator() (C++14) |
返回 value (公共成员函数) |
成员类型
类型 | 定义 |
value_type
|
bool |
type
|
std::integral_constant<bool, value> |
[编辑] 备注
此特性不会检查交换表达式直接上下文之外的任何内容:如果使用T
或U
会触发模板特化,生成隐式定义的特殊成员函数等等,并且这些存在错误,即使std::is_swappable_with<T, U>::value编译并评估为true,实际的交换也可能无法编译。
[编辑] 示例
本节内容不完整 原因:没有示例 |
[编辑] 参见
交换两个对象的的值 (函数模板) | |
(C++11)(C++11)(C++11) |
检查类型是否具有移动赋值运算符 (类模板) |
(C++20) |
指定类型可以交换或两个类型可以相互交换 (概念) |