命名空间
变体
操作

std::sentinel_for

来自 cppreference.com
< cpp‎ | iterator
 
 
迭代器库
迭代器概念
sentinel_for
(C++20)

迭代器基元
算法概念和工具
间接可调用概念
通用算法需求
(C++20)
(C++20)
(C++20)
工具
(C++20)
迭代器适配器
范围访问
(C++11)(C++14)
(C++14)(C++14)  
(C++11)(C++14)
(C++14)(C++14)  
(C++17)(C++20)
(C++17)
(C++17)
 
定义在头文件 <iterator>
template< class S, class I >

    concept sentinel_for =
        std::semiregular<S> &&
        std::input_or_output_iterator<I> &&

        __WeaklyEqualityComparableWith<S, I>;
(自 C++20 起)

sentinel_for 概念指定了 input_or_output_iterator 类型与 semiregular 类型之间的关系,该类型的值表示一个范围。仅供说明的概念 __WeaklyEqualityComparableWithequality_comparable 中有所描述。

[编辑] 语义要求

si 分别为类型 SI 的值,使得 [is) 表示一个 范围。仅当满足以下条件时,sentinel_for<S, I> 才被建模

  • i == s 是定义良好的。
  • 如果 bool(i != s),那么 i 是可解引用的,并且 [++is) 表示一个范围。
  • std::assignable_from<I&, S> 既可以被建模,也可以不满足。

== 的域可能会随着时间推移而发生变化。给定一个迭代器 i 和一个哨兵 s,使得 [is) 表示一个范围,并且 i != s,在对等于 i 的任何迭代器进行递增后,[is) 不需要继续表示一个范围(因此在这样的递增之后,i == s 不需要是定义良好的)。

[编辑] 备注

哨兵类型及其相应的迭代器类型不需要建模 equality_comparable_with,因为哨兵类型可能无法与自身进行比较,并且它们不需要具有公共引用类型。

自 C++17 起,允许在 基于范围的 for 循环 中使用与迭代器类型不同的哨兵类型。

[编辑] 缺陷报告

以下更改行为的缺陷报告被追溯应用于之前发布的 C++ 标准。

DR 应用于 已发布的行为 正确行为
LWG 3453 C++20 sentinel_for 的语义要求对于 ranges::advance 而言过于宽松 加强