Namespaces
Variants

std::ranges::take_view<V>:: end

From cppreference.net
Ranges library
Range adaptors
constexpr auto end ( ) requires ( ! /*simple-view*/ < V > ) ;
(1) (自 C++20 起)
constexpr auto end ( ) const requires ranges:: range < const V > ;
(2) (自 C++20 起)

返回一个哨兵或迭代器,表示 take_view 的结束位置。 take_view 的结束位置要么是底层范围中第 count th 个元素之后的位置,要么是底层范围的结束位置(当后者包含的元素数量少于 count 时)。

1) 返回一个 take_view :: /*sentinel*/ < false > 、一个 std:: default_sentinel_t 或一个 ranges:: iterator_t < V >
2) 返回一个 take_view :: /*sentinel*/ < true > 、一个 std:: default_sentinel_t 或一个 ranges:: iterator_t < const V >

V 简单视图 时(即当 V const V 是具有相同迭代器和哨兵类型的视图时),重载 (1) 不参与重载决议。

目录

参数

(无)

返回值

结果取决于可能带有 const 限定符的底层视图类型 Base 所满足的概念,即对于 ( 1 ) V ,对于 ( 2 ) const V

base_ 为底层视图。

底层视图类型
满足 ...
random_access_range
sized_range ranges:: begin ( base_ ) +
ranges:: range_difference_t < Base_ > ( this - > size ( ) )
std:: default_sentinel
1) /*sentinel*/ < false > { ranges:: end ( base_ ) }
2) /*sentinel*/ < true > { ranges:: end ( base_ ) }

示例

#include <iostream>
#include <iterator>
#include <list>
#include <ranges>
#include <type_traits>
namespace ranges = std::ranges;
namespace views = std::views;
int main()
{
    const auto list1 = {3, 1, 4, 1, 5};
    const auto seq1{list1 | views::take(4)};
    static_assert(ranges::sized_range<decltype(seq1)> and
                  ranges::random_access_range<decltype(seq1)> and
                  std::is_same_v<decltype(seq1.end()), decltype(list1.end())>);
    for (auto it = seq1.begin(); it != seq1.end(); ++it)
        std::cout << *it << ' ';
    std::cout << '\n';
    std::list list2{2, 7, 1, 8, 2};
    const auto seq2{list2 | views::take(4)};
    static_assert(ranges::sized_range<decltype(seq2)> and
                  not ranges::random_access_range<decltype(seq2)> and
                  std::is_same_v<decltype(seq2.end()), std::default_sentinel_t>);
    for (auto it = seq2.begin(); it != std::default_sentinel; ++it)
        std::cout << *it << ' ';
    std::cout << '\n';
}

输出:

3 1 4 1
2 7 1 8

缺陷报告

下列行为变更缺陷报告被追溯应用于先前发布的C++标准。

DR 应用于 发布时的行为 正确行为
P2393R1 C++20 有符号和无符号整数类类型之间的隐式转换可能失败 改为显式转换

参见

返回指向起始位置的迭代器
(公开成员函数)
追踪到范围末尾距离的迭代器适配器
(类模板)
(C++20)
比较哨位与从 take_view::begin 返回的迭代器
(函数)