Namespaces
Variants

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

From cppreference.net
Ranges library
Range adaptors
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

参见

返回指向起始位置的迭代器
(公开成员函数)
返回指示范围结尾的哨兵
(定制点对象)