Namespaces
Variants

std:: is_assignable, std:: is_trivially_assignable, std:: is_nothrow_assignable

From cppreference.net
Metaprogramming library
Type traits
Type categories
(C++11)
(C++11) ( DR* )
Type properties
(C++11)
(C++11)
(C++14)
(C++11) (deprecated in C++26)
(C++11) ( until C++20* )
(C++11) (deprecated in C++20)
(C++11)
Type trait constants
Metafunctions
(C++17)
Supported operations
Relationships and property queries
Type modifications
Type transformations
(C++11) (deprecated in C++23)
(C++11) (deprecated in C++23)
(C++11)
(C++11) ( until C++20* ) (C++17)

Compile-time rational arithmetic
Compile-time integer sequences
定义于头文件 <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 > ( ) 在未求值语境中合法,则提供等于 true 的成员常量 value 。否则 value false 访问检查 的执行方式如同从与任一类型无关的语境进行。
2) (1) 相同,但对赋值表达式的求值不会调用任何非平凡操作。就本检查而言,对 std::declval 的调用被视为平凡操作,且不视为对 std::declval ODR使用
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
[static]
T 可从 U 赋值则为 true ,否则为 false
(公开静态成员常量)

成员函数

operator bool
转换对象为 bool 类型,返回 value
(公开成员函数)
operator()
(C++14)
返回 value
(公开成员函数)

成员类型

类型 定义
value_type bool
type 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 是否可从 int 赋值? "
              << std::is_assignable<int, int>::value << '\n' // 1 = 1; 无法编译
              << "int& 是否可从 int 赋值? "
              << std::is_assignable<int&, int>::value << '\n' // int a; a = 1; 可运行
              << "int 是否可从 double 赋值? "
              << std::is_assignable<int, double>::value << '\n'
              << "int& 是否无异常地从 double 赋值? "
              << std::is_nothrow_assignable<int&, double>::value << '\n'
              << "string 是否可从 double 赋值? "
              << std::is_assignable<std::string, double>::value << '\n'
              << "Ex1& 是否可平凡地从 const Ex1& 赋值? "
              << std::is_trivially_assignable<Ex1&, const Ex1&>::value << '\n';
}

输出:

int 是否可从 int 赋值? false
int& 是否可从 int 赋值? true
int 是否可从 double 赋值? false
int& 是否无异常地从 double 赋值? true
string 是否可从 double 赋值? true
Ex1& 是否可平凡地从 const Ex1& 赋值? true

参见

检查类型是否拥有复制赋值运算符
(类模板)
检查类型是否拥有移动赋值运算符
(类模板)
指定类型可从另一类型赋值
(概念)