std::ranges::cartesian_product_view<First, Vs...>:: iterator <Const>:: next , std::ranges::cartesian_product_view<First, Vs...>:: iterator <Const>:: prev , std::ranges::cartesian_product_view<First, Vs...>:: iterator <Const>:: distance_from
Inhaltsverzeichnis |
std::ranges::cartesian_product_view:: iterator :: next
|
template
<
std::
size_t
N
=
sizeof...
(
Vs
)
>
constexpr void /*next*/ ( ) ; |
(seit C++23)
( nur zur Darstellung* ) |
|
Wenn mit dem Standard-Template-Parameter aufgerufen, erzeugt es rekursiv das nächste Element (das Tupel von Iteratoren) in
cartesian_product_view
.
Sei
current_
das zugrundeliegende Tupel von Iteratoren. Entspricht:
auto& it = std::get<N>(current_); ++it; if constexpr (N > 0) { if (it == ranges::end(std::get<N>(parent_->bases_))) { it = ranges::begin(std::get<N>(parent_->bases_)); next<N - 1>(); } }
Wird in den folgenden nicht-statischen Memberfunktionen verwendet:
-
ranges
::
cartesian_product_view
::
operator+
std::ranges::cartesian_product_view:: iterator :: prev
|
template
<
std::
size_t
N
=
sizeof...
(
Vs
)
>
constexpr void /*prev*/ ( ) ; |
(seit C++23)
( nur zur Darstellung* ) |
|
Wenn mit dem Standard-Template-Parameter aufgerufen, erzeugt es rekursiv das vorherige Element (das Tupel von Iteratoren) in
cartesian_product_view
.
Sei
current_
das zugrundeliegende Tupel von Iteratoren. Entspricht:
auto& it = std::get<N>(current_); if constexpr (N > 0) { if (it == ranges::begin(std::get<N>(parent_->bases_))) { it = /*cartesian-common-arg-end*/(std::get<N>(parent_->bases_)); prev<N - 1>(); } } --it;
Wird in den folgenden nicht-statischen Memberfunktionen verwendet:
-
ranges
::
cartesian_product_view
::
operator-
std::ranges::cartesian_product_view:: iterator :: distance_from
|
template
<
class
Tuple
>
constexpr
difference_type
|
(seit C++23)
( nur zur Darstellung* ) |
|
Gibt die "Distanz" (d.h. Anzahl der "Sprünge") zwischen zwei Iteratoren zurück.
Sei definiert:
-
parent_sei der zugrundeliegende Zeiger aufcartesian_product_view -
/*scaled-size*/
(
N
)
sei:
- das Produkt von static_cast < difference_type > ( ranges:: size ( std :: get < N > ( parent_ - > bases_ ) ) ) und /*scaled-size*/ ( N + 1 ) falls N ≤ sizeof... ( Vs ) , andernfalls
- static_cast < difference_type > ( 1 ) ;
- /*scaled-distance*/ ( N ) sei das Produkt von static_cast < difference_type > ( std :: get < N > ( current_ ) - std :: get < N > ( t ) ) und /*scaled-size*/ ( N + 1 ) ;
- /*scaled-sum*/ sei die Summe von /*scaled-distance*/ ( N ) für jede ganze Zahl 0 ≤ N ≤ sizeof... ( Vs ) .
Rückgabewert: /*scaled-sum*/ .
Das Verhalten ist undefiniert, falls
/*scaled-sum*/
nicht durch
difference_type
dargestellt werden kann.
Wird in folgenden Funktionen verwendet:
-
operator-( const /*iterator*/ & , const /*iterator*/ & ) -
operator-( const /*iterator*/ & , std:: default_sentinel_t )
Parameter
| t | - | ein Tupel von Iteratoren, zu dem die Distanz berechnet werden soll |