std::ranges::cartesian_product_view<First, Vs...>:: end
|
constexpr
iterator
<
false
>
end
(
)
требует
(
(
!
/*simple-view*/
<
First
>
||
...
||
!
/*simple-view*/
<
Vs
>
)
&&
|
(1) | (начиная с C++23) |
|
constexpr
iterator
<
true
>
end
(
)
const
требует /*cartesian-product-is-common*/ < const First, const Vs... > ; |
(2) | (начиная с C++23) |
|
constexpr
std::
default_sentinel_t
end
(
)
const
noexcept
;
|
(3) | (начиная с C++23) |
Возвращает
итератор
или страж, представляющий конец
cartesian_product_view
.
Пусть
bases_
будет базовым кортежем представлений.
return iterator < __is_const > ( /*tuple-transform*/ ( check, bases_ ) ) ; ,
- __is_const равен true для const-квалифицированной перегрузки и false в противном случае.
- __is_empty равен true если выражение ranges:: empty ( rng ) истинно для любого rng среди базовых диапазонов, кроме первого, и false в противном случае.
- __begin_or_first_end ( rng ) является эквивалентным по выражению к __is_empty ? ranges:: begin ( rng ) : /*cartesian-common-arg-end*/ ( rng ) если rng является первым базовым диапазоном, и ranges:: begin ( rng ) в противном случае.
Содержание |
Параметры
(нет)
Возвращаемое значение
Итератор на элемент, следующий за последним элементом, или стражник, который сравнивается равным с конечным итератором.
Пример
#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'); }
Вывод:
long
Смотрите также
|
возвращает итератор на начало
(публичная функция-член) |
|
|
(C++20)
|
возвращает страж, указывающий на конец диапазона
(объект точки настройки) |