名稱空間
變體
操作

std::experimental::ranges::Assignable

來自 cppreference.com
< cpp‎ | experimental‎ | ranges
 
 
實驗性
技術規範
檔案系統庫 (檔案系統 TS)
庫基礎 (庫基礎 TS)
庫基礎 2 (庫基礎 TS v2)
庫基礎 3 (庫基礎 TS v3)
並行性擴充套件 (並行性 TS)
並行性擴充套件 2 (並行性 TS v2)
併發性擴充套件 (併發性 TS)
併發擴充套件 2 (concurrency TS v2)
概念 (概念 TS)
範圍 (範圍 TS)
反射 (反射 TS)
數學特殊函式 (特殊函式 TR)
實驗性非 TS
模式匹配
線性代數
std::execution
契約
2D 圖形
 
 
概念庫
核心語言概念
                              
物件概念
                              
                              
比較概念
可呼叫概念
                                        
                              
URNG 概念
 
定義於標頭檔案 <experimental/ranges/concepts>
template< class T, class U >

concept bool Assignable =
    std::is_lvalue_reference<T>::value &&
    CommonReference<
        const std::remove_reference_t<T>&,
        const std::remove_reference_t<U>&> &&
    requires(T t, U&& u) {
        { t = std::forward<U>(u) } -> Same<T>&&;

    };
(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> 這樣的情況)。