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)
 
 
迭代器库
迭代器概念
间接可调用概念
                                                  
                                                  
                                                  
常用算法要求
                                                  
概念工具
迭代器工具及运算
迭代器特性
迭代器适配器
流迭代器
 
template < class I >

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

  };
(范围 TS)

概念 BidirectionalIterator<I> 细化 ForwardIterator ,添加后移迭代器的能力。

称双向迭代器 r 可自减,若且唯若存在某个 s 使得 ++s == r 。所有可自减迭代器 r 应当在表达式 --rr-- 的定义域中。

abI 类型的可自减对象。 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 表达式中的表达式都要求保持相等性且稳定,而表达式的求值必须只修改其非常运算数。必须不修改常运算数。