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) | (desde C++23) |
|
template
<
bool
OtherConst
>
requires
(
std::
sized_sentinel_for
<
|
(2) | (desde C++23) |
Calcula la distancia mínima entre la tupla subyacente de iteradores de x y la tupla subyacente de centinelas de y .
Estas funciones no son visibles para la búsqueda
no calificada
o
calificada
ordinaria, y solo pueden ser encontradas mediante
búsqueda dependiente de argumentos
cuando
zip_view::
sentinel
<Const>
es una clase asociada de los argumentos.
Parámetros
| x | - | un iterator |
| y | - | un sentinel |
Valor de retorno
Sea
current_
la tupla subyacente de iteradores de
x
, y
end_
la tupla subyacente de centinelas de
y
.
Sea
DIST
(x, y, i)
una distancia calculada por una expresión equivalente a
std
::
get
<
i
>
(
x.
current_
)
-
std
::
get
<
i
>
(
y.
end_
)
para algún entero
i
.
DIST
(x, y, i)
de todos los
i
en el rango
0 ≤ i < sizeof...(Views)
Ejemplo
#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); // El siguiente código genera un error en tiempo de compilación porque std::list::iterator // no soporta el operador- que se necesita para calcular la distancia: // auto e = q.begin() - q.end(); }