std::experimental::ranges::BidirectionalIterator
来自cppreference.com
< 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 表达式中的表达式都要求保持相等性且稳定,而表达式的求值必须只修改其非 const 操作数。必须不修改常运算数。