std::input_or_output_iterator
来自cppreference.com
在标头 <iterator> 定义
|
||
template <class I> concept input_or_output_iterator = |
(C++20 起) | |
input_or_output_iterator
概念组成迭代器分类学的基础;每个迭代器类型都满足 input_or_output_iterator
要求。
仅用于阐释的的概念 __Referenceable
若且唯若表达式 *std::declval<T&>() 合法且拥有可引用类型(特别是非 void )才得到满足。
相等性保持
若表达式对给定的相等输入产生相等输出,则它保持相等性。
- 表达式的输入由其操作数组成。
- 表达式的输出由其结果和表达式所修改的所有操作数(若存在)组成。
在标准概念的规范中,操作数定义为仅包含下列内容的最大子表达式:
- 标识表达式,及
- 对 std::move 、 std::forward 与 std::declval 的调用。
每个操作数的 cv 限定与值类别,是通过假设每个模板类型形参代表一个 cv 无限定的非数组对象类型确定的。
进一步要求每个要求保持相等性的表达式都稳定:这种表达式带相同输入对象的二次求值必须拥有相等的输出,而无任何对这些输入对象的显式中间修改。
除非另外提醒,每个用于 requires 表达式中的表达式都要求保持相等性且稳定,而表达式的求值必须只修改其非常操作数。必须不修改常操作数。
注解
input_or_output_iterator
自身仅指定解引用和自增迭代器的操作。大多数算法将要求额外操作:
- 比较迭代器与哨位(见
sentinel_for
); - 从迭代器读取值(见
indirectly_readable
及input_iterator
); - 写入值到迭代器(见
indirectly_writable
及output_iterator
) - 更丰富的迭代器动作集合(见
forward_iterator
、bidirectional_iterator
、random_access_iterator
)
不同于老式迭代器 (LegacyIterator) 要求, input_or_output_iterator
概念不要求可复制性。