命名空间
变体
动作

std::sentinel_for

来自 cppreference.cn
< 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 而言过于宽松 已加强