std::experimental::ranges::BidirectionalIterator
来自 cppreference.cn
< cpp | experimental | ranges
在头文件 <experimental/ranges/iterator> 中定义 |
||
template< class I > concept bool BidirectionalIterator = |
(ranges TS) | |
概念 BidirectionalIterator<I>
细化了 ForwardIterator
,通过增加向后移动迭代器的能力。
如果存在某个 s
使得 ++s == r,则称双向迭代器 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-expression 中使用的每个表达式都必须是相等性保持和稳定的,并且表达式的评估可能仅修改其非常量操作数。常量操作数不得修改。