std::sentinel_for
来自 cppreference.com
定义在头文件 <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 而言过于宽松 |
加强 |