名稱空間
變體
操作

std::experimental::ranges::BidirectionalIterator

來自 cppreference.com
< cpp‎ | experimental‎ | ranges
 
 
實驗性
技術規範
檔案系統庫 (檔案系統 TS)
庫基礎 (庫基礎 TS)
庫基礎 2 (庫基礎 TS v2)
庫基礎 3 (庫基礎 TS v3)
並行性擴充套件 (並行性 TS)
並行性擴充套件 2 (並行性 TS v2)
併發性擴充套件 (併發性 TS)
併發擴充套件 2 (併發 TS v2)
概念 (概念 TS)
範圍 (範圍 TS)
反射 (反射 TS)
數學特殊函式 (特殊函式 TR)
實驗性非 TS
模式匹配
線性代數
std::execution
契約
2D 圖形
 
 
迭代器庫
迭代器概念
間接可呼叫概念
                                                  
                                                  
                                                  
常用演算法要求
                                                  
概念工具
迭代器工具與操作
迭代器特徵
迭代器介面卡
流迭代器
 
定義於標頭檔案 <experimental/ranges/iterator>
template< class I >

concept bool BidirectionalIterator =
    ForwardIterator<I> &&
    DerivedFrom<ranges::iterator_category_t<I>, ranges::bidirectional_iterator_tag> &&
    requires(I i) {
        { --i } -> Same<I>&;
        { i-- } -> Same<I>&&;

    };
(ranges TS)

概念 BidirectionalIterator<I> 透過新增向後移動迭代器的能力來細化 ForwardIterator

當且僅當存在某個 s 使得 ++s == r 時,雙向迭代器 r 才被稱為可遞減的。所有可遞減的迭代器 r 都應在表示式 --rr-- 的域中。

ab 為型別 I 的可遞減物件。BidirectionalIterator<I> 僅在滿足以下條件時才成立:

  • 前遞減產生一個左值,該左值引用運算元:std::addressof(--a) == std::addressof(a)
  • 後遞減產生運算元的先前值:如果 bool(a == b),則 bool(a-- == b)
  • 後遞減和前遞減對運算元執行相同的修改:如果 bool(a == b),則在評估 a----b 之後,bool(a == b) 仍然成立。
  • 增量和減量互為逆運算:
  • 如果 a 可增量且 bool(a == b),則 bool(--(++a) == b)
  • 如果 bool(a == b),則 bool(++(--a) == b)

[編輯] 相等性保持

如果一個表示式在給定相等輸入時產生相等輸出,則稱其為保持相等性

  • 表示式的輸入由其運算元組成。
  • 表示式的輸出由其結果以及被表示式修改的所有運算元(如果有的話)組成。

所有要求保持相等性的表示式還必須是穩定的:在沒有顯式介入修改輸入物件的情況下,對具有相同輸入物件的表示式的兩次求值必須產生相等的輸出。

除非另有說明,requires-expression 中使用的每個表示式都必須保持相等且穩定,並且表示式的評估只能修改其非常量運算元。常量運算元不得修改。