std::is_assignable, std::is_trivially_assignable, std::is_nothrow_assignable
来自 cppreference.cn
定义于头文件 <type_traits> |
||
template< class T, class U > struct is_assignable; |
(1) | (C++11 起) |
template< class T, class U > struct is_trivially_assignable; |
(2) | (C++11 起) |
template< class T, class U > struct is_nothrow_assignable; |
(3) | (C++11 起) |
1) 如果表达式 std::declval<T>() = std::declval<U>() 在未求值上下文中形式良好,则提供成员常量 value 等于 true。否则,value 为 false。访问检查 执行时,如同来自与任一类型都无关的上下文。
3) 同 (1),但赋值表达式的求值将不调用任何非 noexcept 操作。
如果 T
或 U
不是完整类型、(可能带 cv 限定的)void,或未知边界的数组,则行为未定义。
如果上述模板的实例化直接或间接依赖于不完整类型,并且该实例化在该类型假设完成时可能产生不同的结果,则行为未定义。
如果程序为此页上描述的任何模板添加特化,则行为未定义。
目录 |
[编辑] 辅助变量模板
template< class T, class U > constexpr bool is_assignable_v = is_assignable<T, U>::value; |
(C++17 起) | |
template< class T, class U > constexpr bool is_trivially_assignable_v = is_trivially_assignable<T, U>::value; |
(C++17 起) | |
template< class T, class U > constexpr bool is_nothrow_assignable_v = is_nothrow_assignable<T, U>::value; |
(C++17 起) | |
继承自 std::integral_constant
成员常量
value [静态] |
true 如果 T 可以从 U 赋值,否则为 false(public static 成员常量) |
成员函数
operator bool |
将对象转换为 bool,返回 value (公开成员函数) |
operator() (C++14) |
返回 value (公开成员函数) |
成员类型
类型 | 定义 |
value_type
|
bool |
类型
|
std::integral_constant<bool, value> |
[编辑] 注意
此特性不检查赋值表达式的直接上下文之外的任何内容:如果使用 T
或 U
将触发模板特化、隐式定义特殊成员函数的生成等,并且这些有错误,则实际赋值可能无法编译,即使 std::is_assignable<T,U>::value 编译并评估为 true。
[编辑] 示例
运行此代码
#include <iostream> #include <string> #include <type_traits> struct Ex1 { int n; }; int main() { std::cout << std::boolalpha << "int is assignable from int? " << std::is_assignable<int, int>::value << '\n' // 1 = 1; wouldn't compile << "int& is assignable from int? " << std::is_assignable<int&, int>::value << '\n' // int a; a = 1; works << "int is assignable from double? " << std::is_assignable<int, double>::value << '\n' << "int& is nothrow assignable from double? " << std::is_nothrow_assignable<int&, double>::value << '\n' << "string is assignable from double? " << std::is_assignable<std::string, double>::value << '\n' << "Ex1& is trivially assignable from const Ex1&? " << std::is_trivially_assignable<Ex1&, const Ex1&>::value << '\n'; }
输出
int is assignable from int? false int& is assignable from int? true int is assignable from double? false int& is nothrow assignable from double? true string is assignable from double? true Ex1& is trivially assignable from const Ex1&? true
[编辑] 参阅
(C++11)(C++11)(C++11) |
检查类型是否具有拷贝赋值运算符 (类模板) |
(C++11)(C++11)(C++11) |
检查类型是否有移动赋值运算符 (类模板) |
(C++20) |
指定类型可从另一类型赋值 (概念) |