std::sentinel_for
来自 cppreference.cn
定义于头文件 <iterator> |
||
template< class S, class I > concept sentinel_for = |
(自 C++20 起) | |
sentinel_for
概念指定了 input_or_output_iterator
类型和 semiregular
类型之间的关系,后者的值表示一个范围。仅用于阐释的概念 __WeaklyEqualityComparableWith
在 equality_comparable
中描述。
[编辑] 语义要求
设 s
和 i
分别为 S
和 I
类型的值,使得 [
i,
s)
表示一个 范围。仅当以下条件成立时,sentinel_for<S, I>
才被建模:
- i == s 是良定义的。
- 如果 bool(i != s) 则
i
是可解引用的,并且[
++i,
s)
表示一个范围。 - std::assignable_from<I&, S> 要么被建模,要么不满足。
==
的域可以随时间变化。给定一个迭代器 i
和哨位 s
,使得 [
i,
s)
表示一个范围且 i != s,在递增任何等于 i
的迭代器之后,[
i,
s)
不必继续表示一个范围(因此在这样的递增之后,i == s 不再需要是良定义的)。
[编辑] 注解
哨位类型及其对应的迭代器类型不需要建模 equality_comparable_with
,因为哨位类型可能无法与其自身比较,并且它们不需要具有公共引用类型。
自 C++17 以来,在 基于范围的 for
循环中使用与迭代器类型不同的哨位类型是被允许的。
[编辑] 缺陷报告
以下行为变更缺陷报告被追溯应用于先前发布的 C++ 标准。
DR | 应用于 | 已发布行为 | 正确行为 |
---|---|---|---|
LWG 3453 | C++20 | sentinel_for 的语义要求对于 ranges::advance 而言过于宽松 |
已加强 |