std::ranges::cartesian_product_view<First, Vs...>:: end
|
constexpr
iterator
<
false
>
end
(
)
requiere
(
(
!
/*simple-view*/
<
First
>
||
...
||
!
/*simple-view*/
<
Vs
>
)
&&
|
(1) | (desde C++23) |
|
constexpr
iterator
<
true
>
end
(
)
const
requiere /*cartesian-product-is-common*/ < const First, const Vs... > ; |
(2) | (desde C++23) |
|
constexpr
std::
default_sentinel_t
end
(
)
const
noexcept
;
|
(3) | (desde C++23) |
Devuelve un
iterator
o un sentinel que representa el final del
cartesian_product_view
.
Sea
bases_
la tupla subyacente de vistas.
return iterator < __is_const > ( /*tuple-transform*/ ( check, bases_ ) ) ; ,
- __is_const es true para la sobrecarga calificada const , y false en caso contrario.
- __is_empty es true si la expresión ranges:: empty ( rng ) es true para cualquier rng entre los rangos subyacentes excepto el primero y false en caso contrario.
- __begin_or_first_end ( rng ) es equivalente-expresión a __is_empty ? ranges:: begin ( rng ) : /*cartesian-common-arg-end*/ ( rng ) si rng es el primer rango subyacente y ranges:: begin ( rng ) en caso contrario.
Contenidos |
Parámetros
(ninguno)
Valor de retorno
Un iterador al elemento que sigue al último elemento, o un centinela que se compara igual al iterador final.
Ejemplo
#include <array> #include <format> #include <iostream> #include <ranges> #include <string_view> #include <tuple> using namespace std::literals; int main() { constexpr auto a = std::array{ "bool"sv, "goto"sv, "extern"sv, "long"sv }; /* ^ ^ ^ ^ */ constexpr auto v = std::ranges::cartesian_product_view(a[0], a[1], a[2], a[3]); constexpr std::tuple<char const&, char const&, char const&, char const&> last{*(v.end() - 1)}; std::cout << std::format("{}{}{}{}{}", std::get<0>(last), std::get<1>(last), std::get<2>(last), std::get<3>(last), '\n'); }
Salida:
long
Véase también
|
devuelve un iterador al inicio
(función miembro pública) |
|
|
(C++20)
|
devuelve un centinela que indica el final de un rango
(objeto de punto de personalización) |