operator- (ranges::zip_view:: sentinel )
|
||||||||||||||||||||||
| Range primitives | |||||||
|
|||||||
| Range concepts | |||||||||||||||||||
|
|||||||||||||||||||
| Range factories | |||||||||
|
|||||||||
| Range adaptors | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||
| Helper items | |||||||||||||||||
|
|
||||||||||||||||
| Member functions | ||||
| Deduction guides | ||||
| Iterator | ||||
| Member functions | ||||
| Non-member functions | ||||
| Sentinel | ||||
| Member functions | ||||
| Non-member functions | ||||
|
operator-
(zip_view::
iterator
,zip_view::
sentinel
)
|
|
template
<
bool
OtherConst
>
erfordert
(
std::
sized_sentinel_for
<
|
(1) | (seit C++23) |
|
template
<
bool
OtherConst
>
erfordert
(
std::
sized_sentinel_for
<
|
(2) | (seit C++23) |
Berechnet die minimale Distanz zwischen dem zugrundeliegenden Tupel von Iteratoren von x und dem zugrundeliegenden Tupel von Sentinels von y .
Diese Funktionen sind für gewöhnliches
unqualified
oder
qualified lookup
nicht sichtbar und können nur durch
argument-dependent lookup
gefunden werden, wenn
zip_view::
sentinel
<Const>
eine assoziierte Klasse der Argumente ist.
Parameter
| x | - | ein iterator |
| y | - | ein sentinel |
Rückgabewert
Sei
current_
das zugrundeliegende Tupel von Iteratoren von
x
, und
end_
das zugrundeliegende Tupel von Sentinels von
y
.
Sei
DIST
(x, y, i)
eine Entfernung, berechnet durch einen Ausdruck äquivalent zu
std
::
get
<
i
>
(
x.
current_
)
-
std
::
get
<
i
>
(
y.
end_
)
für eine ganze Zahl
i
.
DIST
(x, y, i)
für alle
i
im Bereich
0 ≤ i < sizeof...(Views)
Beispiel
#include <cassert> #include <deque> #include <list> #include <ranges> #include <vector> int main() { auto x = std::vector{1, 2, 3, 4}; auto y = std::deque{'a', 'b', 'c'}; auto z = {1.1, 2.2}; auto w = std::list{1, 2, 3}; auto p = std::views::zip(x, y, z); assert(p.begin() - p.end() == +2); assert(p.end() - p.begin() == -2); [[maybe_unused]] auto q = std::views::zip(x, y, w); // Der folgende Code erzeugt einen Compile-Time-Fehler, weil std::list::iterator // den operator- nicht unterstützt, der zur Berechnung der Distanz benötigt wird: // auto e = q.begin() - q.end(); }