std::ranges::take_view<V>::begin

来自cppreference.com
< cpp‎ | ranges‎ | take view
 
 
范围库
范围适配器
 
 
constexpr auto begin() requires (!/*simple-view*/<V>);
(1) (C++20 起)
constexpr auto begin() const requires ranges::range<const V>;
(2) (C++20 起)

返回指向 take_view 首元素的迭代器。

2) 返回 std::counted_iteratorranges::iterator_t<const V>

重载 (1) 仅若 V简单视图(即若 Vconst V 均为视图且拥有相同迭代器与哨位类型)才参与重载决议。

参数

(无)

返回值

结果依赖于可能为 const 限定的底层视图类型 Base,即对于 (1)V 或对于 (2)const V

base_ 为底层视图,count_ 为底层计数器(若 take_view 默认初始化则等于 0)。

底层视图类型满足…… random_access_range
sized_range ranges::begin(base_) std::counted_iterator(ranges::begin(base_),
    ranges::range_difference_t<Base_>(this->size()))
std::counted_iterator(ranges::begin(base_), count_)

示例

#include <concepts>
#include <forward_list>
#include <iostream>
#include <ranges>
#include <string_view>
#include <type_traits>
using namespace std::literals;
 
int main()
{
    {
        static constexpr auto v = {"∀x"sv, "∃y"sv, "ε"sv, "δ"sv};
        auto view = std::ranges::take_view(v, 8);
        auto iter = view.begin();
        std::cout << *iter << '\n';
        static_assert(
            std::ranges::sized_range<decltype(v)> and
            std::ranges::random_access_range<decltype(v)> and
            std::is_same_v<decltype(iter), decltype(std::ranges::begin(v))>
        );
    }
 
    {
        std::forward_list v = {"Ax"sv, "Ey"sv, "p"sv, "q"sv};
        auto view = std::ranges::take_view(v, 8);
        auto iter = view.begin();
        std::cout << *iter << '\n';
        static_assert(
            not std::ranges::sized_range<decltype(v)> and
            not std::ranges::random_access_range<decltype(v)> and
            std::is_same_v<decltype(iter),
                std::counted_iterator<
                    std::forward_list<std::string_view>::iterator>>
        );
    }
}

输出:

∀x
Ax

缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告 应用于 出版时的行为 正确行为
P2393R1 C++20 有符号与无符号整数类间的隐式转换可能失败 使之为显式

参阅

返回 指向末尾的迭代器或哨位
(公开成员函数)
对到范围结尾距离进行跟踪的迭代器适配器
(类模板)
比较哨位与 take_view::begin 返回的迭代器
(函数)