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
>
requires
(
std::
sized_sentinel_for
<
|
(1) | (depuis C++23) |
|
template
<
bool
OtherConst
>
requires
(
std::
sized_sentinel_for
<
|
(2) | (depuis C++23) |
Calcule la distance minimale entre le tuple sous-jacent d'itérateurs de x et le tuple sous-jacent de sentinelles de y .
Ces fonctions ne sont pas visibles par la recherche
non qualifiée
ou
qualifiée
ordinaire, et ne peuvent être trouvées que par la recherche
dépendante des arguments
lorsque
zip_view::
sentinel
<Const>
est une classe associée des arguments.
Paramètres
| x | - | un iterator |
| y | - | une sentinel |
Valeur de retour
Soit
current_
le tuple sous-jacent d'itérateurs de
x
, et
end_
le tuple sous-jacent de sentinelles de
y
.
Soit
DIST
(x, y, i)
une distance calculée par une expression équivalente à
std
::
get
<
i
>
(
x.
current_
)
-
std
::
get
<
i
>
(
y.
end_
)
pour un entier
i
donné.
DIST
(x, y, i)
pour tous les
i
dans l'intervalle
0 ≤ i < sizeof...(Views)
Exemple
#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); // Le code suivant génère une erreur de compilation car std::list::iterator // ne supporte pas l'opérateur- nécessaire pour calculer la distance : // auto e = q.begin() - q.end(); }