std::assignable_from
来自cppreference.com
定义于头文件 <concepts>
|
||
template< class LHS, class RHS > concept assignable_from = |
(C++20 起) | |
概念 assignable_from<LHS, RHS>
指定能赋值类型和值类别由 RHS
编码的表达式给类型为 LHS
所指定的左值表达式。
给定
-
lhs
,指代对象lcopy
的左值,使得 decltype((lhs)) 为LHS
, -
rhs
,使得 decltype((rhs)) 为RHS
的表达式, -
rcopy
,等于rhs
的单独对象,
assignable_from<LHS, RHS>
仅若符合下列条件才得到满足
- std::addressof(lhs = rhs) == std::addressof(lcopy) (即赋值表达式生成指代左运算数的左值);
- 求值 lhs = rhs 后:
-
lhs
等于rcopy
,除非rhs
是指代lcopy
的非 const 亡值(即赋值为自移动赋值), - 若
rhs
是泛左值;- 若它是非 const 亡值,则其所指代的对象在合法但未指定的状态;
- 否则,不修改其所指代的对象;
-
相等性保持
若表达式对给定的相等输入产生相等输出,则它保持相等性。
- 表达式的输入由其运算数组成。
- 表达式的输出由其结果和表达式所修改的所有运算数(若存在)组成。
进一步要求每个要求保持相等性的表达式都稳定:这种表达式带相同输入对象的二次求值必须拥有相等的输出,而无任何对这些输入对象的显式中间修改。
除非另外提醒,每个用于 requires 表达式中的表达式都要求保持相等性且稳定,而表达式的求值必须只修改其非常运算数。必须不修改常运算数。
注意
赋值不必为全函数。具体来说,若赋值给某对象 x
可能导致修改某其他对象 y
,则 x = y 可能不在 =
的定义域中。若左运算数直接或间接占有右运算数(例如用指向基于结点的数据结构中的结点的智能指针,或用类似 std::vector<std::any> 的构造),则这常发生。
参阅
(C++11)(C++11)(C++11) |
检查类型是否拥有针对特定实参的赋值运算符 (类模板) |