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) | (since C++23) |
constexpr iterator<true> end() const requires /*cartesian-product-is-common*/<const First, const Vs...>; |
(2) | (since C++23) |
constexpr std::default_sentinel_t end() const noexcept; |
(3) | (since 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) |
返回一个哨兵,指示范围的末尾 (定制点对象) |