命名空间
变体
操作

std::ranges::cartesian_product_view<First, Vs...>::end

来自 cppreference.com
 
 
范围库
范围适配器
 
 
constexpr iterator<false> end()

    requires ((!/*simple-view*/<First> || ... || !/*simple-view*/<Vs>) &&

        /*cartesian-product-is-common*/<First, 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_));
,
其中
  • __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

[编辑] 另请参阅

返回指向起始位置的迭代器
(公共成员函数) [编辑]
返回一个指示范围末尾的哨兵
(定制点对象)[编辑]