命名空间
变体
操作

std::ranges::slide_view<V>::begin

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

返回指向 slide_view 的第一个元素的迭代器。

1) 如果 V 符合 slide-caches-first,等效于

return iterator<false>(
           ranges::begin(base_),
           ranges::next(ranges::begin(base_), n_ - 1, ranges::end(base_)),
           n_
       );

否则,等效于: return iterator<false>(ranges::begin(base_), n_);.
如果 V 符合 slide-caches-first,此函数会将结果缓存到 cached_begin_ 中,以便在后续调用中使用。这是为了提供 range 所需的摊销常数时间复杂度。
2) 等效于: return iterator<true>(ranges::begin(base_), n_);.

内容

[编辑] 参数

(无)

[编辑] 返回值

指向 slide_view 的第一个元素的 迭代器,指向可能限定为 const 的基础视图类型的 n_ 大小子范围 – 对于重载 (1)V,对于重载 (2)const V

[编辑] 示例

#include <iostream>
#include <ranges>
#include <string_view>
using namespace std::literals;
 
int main()
{
    static constexpr auto source = {"∀x"sv, "∃y"sv, "ε"sv, "δ"sv};
    auto view{std::ranges::slide_view(source, 2)};
    const auto subrange{*(view.begin())};
    for (std::string_view const s : subrange)
        std::cout << s << ' ';
    std::cout << '\n';
}

输出

∀x ∃y

[编辑] 另请参阅

返回指向结尾的迭代器或哨兵
(公共成员函数) [编辑]
将哨兵与从 slide_view::begin 返回的迭代器进行比较
(函数) [编辑]