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。
- 若表达式 ranges::empty(rng) 对除第一个范围之外的任何底层范围 rng 中都为 true,则 __is_empty 为 true,否则为 false。
- 若 rng 为第一个底层的范围,则 __begin_or_first_end(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) |
返回指示范围结尾的哨位 (定制点对象) |