std::ranges::cartesian_product_view<First, Vs...>::end
来自 cppreference.com
< cpp | ranges | cartesian product view
constexpr iterator<false> end() requires ((!/*simple-view*/<First> || ... || !/*simple-view*/<Vs>) && |
(1) | (自 C++23) |
constexpr iterator<true> end() const requires /*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_
为底层视图元组。
1,2) 等效于
auto check = [](auto& rng) { return __begin_or_first_end(rng); };
return iterator<__is_const>(/*tuple-transform*/(check, bases_));,
return iterator<__is_const>(/*tuple-transform*/(check, bases_));,
其中
- __is_const 对于带 const 限定符的重载为 true,否则为 false。
- __is_empty 如果表达式 ranges::empty(rng) 对于底层范围中的任何 rng(除第一个以外)为 true,则为 true,否则为 false。
- __begin_or_first_end(rng) 如果 rng 是第一个底层范围,则表达式等效于 __is_empty ? ranges::begin(rng) : /*cartesian-common-arg-end*/(rng),否则表达式等效于 ranges::begin(rng)。
3) 等效于:return std::default_sentinel;.
内容 |
[编辑] 参数
(无)
[编辑] 返回值
指向最后一个元素之后元素的 迭代器,或一个与末尾迭代器相等的哨兵。
[编辑] 示例
运行此代码
#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) |
返回一个指示范围末尾的哨兵 (定制点对象) |