Difference between revisions of "cpp/ranges/stride view/iterator/iterator"
From cppreference.com
< cpp | ranges | stride view | iterator
(+page) |
(Correct a few minor typos in the semantics of (3).) |
||
Line 37: | Line 37: | ||
@3@ A private constructor which is used by {{lc|stride_view::begin}} and {{lc|stride_view::end}}. This constructor is not accessible to users. Initializes | @3@ A private constructor which is used by {{lc|stride_view::begin}} and {{lc|stride_view::end}}. This constructor is not accessible to users. Initializes | ||
* {{rlpi|/#Data members|current_}} with {{c|std::move(current)}}, | * {{rlpi|/#Data members|current_}} with {{c|std::move(current)}}, | ||
− | * {{rlpi|/#Data members|end_}} with {{c| | + | * {{rlpi|/#Data members|end_}} with {{c|ranges::end(parent->base_)}}, |
− | * {{rlpi|/#Data members|stride_}} with {{c|parent-> | + | * {{rlpi|/#Data members|stride_}} with {{c|parent->stride_}}, |
− | * {{rlpi|/#Data members|missing_}} with {{c| | + | * {{rlpi|/#Data members|missing_}} with {{c|missing}}. |
===Parameters=== | ===Parameters=== |
Revision as of 18:29, 2 August 2023
/*iterator*/() requires std::default_initializable<ranges::iterator_t<Base>> = default; |
(1) | (since C++23) |
constexpr /*iterator*/( /*iterator*/<!Const> i ) requires Const and |
(2) | (since C++23) |
private: constexpr /*iterator*/( /*Parent*/& parent, // exposition only |
(3) | (since C++23) |
Construct an iterator.
1) Default constructor. Value-initializes:
-
current_
with ranges::iterator_t<Base>(), -
end_
with ranges::sentinel_t<Base>(), -
stride_
with 0, -
missing_
with 0.
2) Conversion from /*iterator*/<false> to /*iterator*/<true>. Initializes:
3) A private constructor which is used by stride_view::begin and stride_view::end. This constructor is not accessible to users. Initializes
-
current_
with std::move(current), -
end_
with ranges::end(parent->base_), -
stride_
with parent->stride_, -
missing_
with missing.
Parameters
i | - | an /*iterator*/<false> |
Example
This section is incomplete Reason: no example |