std::ranges::adjacent_transform_view<V,F,N>::iterator
From cppreference.com
< cpp | ranges | adjacent transform view
template< bool Const > class /*iterator*/ |
(since C++23) | |
The return type of adjacent_transform_view::begin
, and of adjacent_transform_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 two non-static data members:
-
parent_
of typeParent*
, and -
inner_
of typeinner_iterator
.
These names are for exposition only.
Member types
Member type | Definition |
Parent (private)
|
const ranges::adjacent_transform_view, if Const is true. Otherwise, ranges::adjacent_transform_view. The name is for exposition only. |
Base (private)
|
const V, if Const is true. Otherwise, V. The name is for exposition only. |
iterator_category
|
|
iterator_concept
|
typename /*inner-iterator*/<Const>::iterator_concept;. |
value_type
|
std::remove_cvref_t<std::invoke_result_t</*maybe-const*/<Const, F>&, |
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) |
Example
This section is incomplete Reason: no example |
References
- C++23 standard (ISO/IEC 14882:2023):
- 26.7.27.3 Class template adjacent_transform_view::iterator [range.adjacent_transform.iterator]