std::ranges::adjacent_view<V,N>::iterator
From cppreference.com
< cpp | ranges | adjacent view
template< bool Const > class /*iterator*/ |
(since C++23) | |
The return type of adjacent_view::begin
, and of adjacent_view::end
when the underlying view V
is a common_range
.
The type /*iterator*/<true> is returned by the const-qualified overloads. The type /*iterator*/<false> is returned by the non-const-qualified overloads.
The name of this class template (shown here as /*iterator*/) is unspecified.
Data members
Typical implementations of /*iterator*/ hold only one non-static data member current_
of type std::array<ranges::iterator_t<Base>, N>. The name is for exposition only.
Member types
Member type | Definition |
Base (private)
|
const V if Const is true, otherwise V. The name is for exposition only. |
iterator_category
|
std::input_iterator_tag |
iterator_concept
|
|
value_type
|
std::tuple</*REPEAT*/(ranges::range_value_t<Base>, N)...>; |
difference_type
|
ranges::range_difference_t<Base> |
Member functions
(C++23) |
constructs an iterator (public member function) |
(C++23) |
accesses the element (public member function) |
(C++23) |
accesses an element by index (public member function) |
advances or decrements the underlying iterators (public member function) |
Non-member functions
compares the underlying iterators (function) | |
(C++23) |
performs iterator arithmetic (function) |
(C++23) |
casts the result of dereferencing the underlying iterator to its associated rvalue reference type (function) |
(C++23) |
swaps the objects pointed to by two underlying iterators (function) |
Example
This section is incomplete Reason: no example |
References
- C++23 standard (ISO/IEC 14882:2023):
- 26.7.25.3 Class template
adjacent_view::iterator
[range.adjacent.iterator]
- 26.7.25.3 Class template