Thesentinel_for
concept specifies the relationship between aninput_or_output_iterator
type and asemiregular
type whose values denote a range. The exposition-only concept__WeaklyEqualityComparableWith
is described inequality_comparable
.
[edit]Semantic requirements
Lets
andi
be values of typeS
andI
, respectively, such that[
i,
s)
denotes arange.sentinel_for<S, I>
is modeled only if:
- i== s is well-defined.
- Ifbool(i!= s) then
i
is dereferenceable and[
++i,
s)
denotes a range. - std::assignable_from<I&, S> is either modeled or not satisfied.
The domain of==
can change over time. Given an iteratori
and sentinels
such that[
i,
s)
denotes a range andi!= s,[
i,
s)
is not required to continue to denote a range after incrementing any iterator equal toi
(and soi== s is no longer required to be well-defined after such an increment).
A sentinel type and its corresponding iterator type are not required to modelequality_comparable_with
, because the sentinel type may not be comparable with itself, and they are not required to have a common reference type.
It has been permitted to use a sentinel type different from the iterator type in therange-basedfor
loop since C++17.
[edit]Defect reports
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
DR | Applied to | Behavior as published | Correct behavior |
---|
LWG 3453 | C++20 | semantic requirements forsentinel_for were too loose forranges::advance | strengthened |