std::experimental::ranges::Assignable
定義於標頭檔案 <experimental/ranges/concepts> |
||
template< class T, class U > concept bool Assignable = |
(ranges TS) | |
概念 Assignable<T, U>
指定了型別為 U
的表示式可以賦值給型別為 T
的左值表示式。
給定
-
t
,一個型別為 std::remove_reference_t<T> 的左值,引用物件o
, -
u
,一個表示式,其 decltype((u)) 為U
, -
u2
,一個與u
相等的不同物件,
Assignable<T, U>
僅在以下情況滿足:
- std::addressof(t = u) == std::addressof(o) (即賦值表示式產生一個引用左運算元的左值);
- 在評估 t = u 之後
-
t
等於u2
,除非u
是一個引用o
的非 const xvalue(即賦值是自移動賦值), - 如果
u
是一個 glvalue- 如果它是一個非 const xvalue,它所引用的物件處於有效但未指定的狀態;
- 否則,它所引用的物件未被修改;
-
Assignable<T, U>
和 std::is_lvalue_reference<T>::value 之間不需要存在任何從屬關係。
[編輯] 相等性保持
如果一個表示式在給定相等輸入時產生相等輸出,則稱其為保持相等性。
- 表示式的輸入由其運算元組成。
- 表示式的輸出由其結果以及被表示式修改的所有運算元(如果有的話)組成。
所有要求保持相等性的表示式還必須是穩定的:在沒有顯式介入修改輸入物件的情況下,對具有相同輸入物件的表示式的兩次求值必須產生相等的輸出。
除非另有說明,requires-expression 中使用的每個表示式都必須保持相等且穩定,並且表示式的評估只能修改其非常量運算元。常量運算元不得修改。
[編輯] 注意
形式為 { expression } -> Same<T>&& 的推導約束實際上要求 decltype((expression))&& 與 T&&
是完全相同的型別。這約束了表示式的型別及其值類別。
賦值不一定是全函式。特別是,如果將某個物件 x
賦值可能導致另一個物件 y
被修改,那麼 x = y 很可能不在 =
的定義域內。這通常發生在右運算元直接或間接由左運算元擁有時(例如,帶節點資料結構中節點的智慧指標,或者像 std::vector<std::any> 這樣的情況)。