std::experimental::ranges::BidirectionalIterator
< cpp | experimental | ranges
template < class I > concept bool BidirectionalIterator = |
(范围 TS) | |
概念 BidirectionalIterator<I>
细化 ForwardIterator
,添加后移迭代器的能力。
称双向迭代器 r
可自减,若且唯若存在某个 s
使得 ++s == r 。所有可自减迭代器 r
应当在表达式 --r 和 r-- 的定义域中。
令 a
与 b
为 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 表达式中的表达式都要求保持相等性且稳定,而表达式的求值必须只修改其非常运算数。必须不修改常运算数。