命名空间
变体
操作

std::experimental::ranges::迭代器

来自 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图形
 
 
迭代器库
迭代器概念
间接可调用概念
                                                  
                                                  
                                                  
常用算法要求
                                                  
概念工具
迭代器工具和操作
迭代器 traits
迭代器适配器
流迭代器
 
template< class I >

concept bool Iterator =
    requires(I i) {
        { *i } -> auto&&; // 要求:i 可解引用
    } &&

    WeaklyIncrementable<I>;
(ranges TS)

Iterator 概念构成了迭代器概念分类的基础;每个迭代器都满足 Iterator 的要求。

[编辑] 相等保持

如果一个表达式在给定相等输入时产生相等输出,则该表达式是相等保持的。

  • 表达式的输入由其操作数组成。
  • 表达式的输出由其结果和表达式修改的所有操作数(如果有)组成。

每个要求相等保持的表达式还必须是稳定的:在没有显式干预修改这些输入对象的情况下,对具有相同输入对象的此类表达式的两次求值必须具有相等的输出。

除非另有说明,否则在 requires-expression 中使用的每个表达式都必须是相等保持和稳定的,并且表达式的求值可能只会修改其非常量操作数。常量操作数不得修改。

[编辑] 注释

Iterator 本身仅指定了用于解引用和递增迭代器的操作。大多数算法将需要额外的操作,例如

-> auto&& 约束意味着解引用的结果类型不能是 void