std::ranges::cartesian_product_view<First, Vs...>::end
来自 cppreference.cn
< 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) 表达式等价于 __is_empty ? ranges::begin(rng) : /*cartesian-common-arg-end*/(rng),如果 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) |
返回指示范围末尾的哨兵 (定制点对象) |