命名空间
变体
操作

std::experimental::ranges::BidirectionalIterator

来自 cppreference.cn
< cpp‎ | experimental‎ | ranges
 
 
实验性
技术规范
文件系统库 (filesystem TS)
库基础 (library fundamentals TS)
库基础 2 (library fundamentals TS v2)
库基础 3 (library fundamentals TS v3)
并行性扩展 (parallelism TS)
并行性扩展 2 (parallelism TS v2)
并发性扩展 (concurrency TS)
并发性扩展 2 (concurrency TS v2)
概念 (concepts TS)
范围 (ranges TS)
反射 (reflection TS)
数学特殊函数 (special functions TR)
实验性非 TS
模式匹配
线性代数
std::execution
契约
2D 图形
 
 
迭代器库
迭代器概念
间接可调用概念
                                                  
                                                  
                                                  
常用算法要求
                                                  
概念工具
迭代器工具和操作
迭代器特性
迭代器适配器
流迭代器
 
在头文件 <experimental/ranges/iterator> 中定义
template< class I >

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

    };
(ranges TS)

概念 BidirectionalIterator<I> 细化了 ForwardIterator,通过增加向后移动迭代器的能力。

如果存在某个 s 使得 ++s == r,则称双向迭代器 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-expression 中使用的每个表达式都必须是相等性保持和稳定的,并且表达式的评估可能仅修改其非常量操作数。常量操作数不得修改。