命名空间
变体
操作

std::experimental::ranges::BidirectionalIterator

来自 cppreference.cn
< 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 图形
 
 
迭代器库
迭代器概念
间接可调用概念
                                                  
                                                  
                                                  
常用算法要求
                                                  
概念工具
迭代器工具与操作
迭代器特征
迭代器适配器
流迭代器
 
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 中使用的每个表达式都必须保持相等且稳定,并且表达式的评估只能修改其非常量操作数。常量操作数不得修改。