C++ 参考手册

位置:首页 > > std::experimental::ranges::BidirectionalIterator

定义于头文件 <experimental/ranges/iterator>
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 表达式中的表达式都要求保持相等性且稳定,而表达式的求值必须只修改其非常运算数。必须不修改常运算数。