名稱空間
變體
操作

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

來自 cppreference.com
< cpp‎ | ranges‎ | slide_view
 
 
範圍庫 (Ranges library)
範圍介面卡 (Range adaptors)
 
 
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)Vslide-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_);
Vslide-caches-first 建模,此函式會在 cached_begin_ 中快取結果,以用於後續呼叫。這對於提供 range 所要求的均攤常數時間複雜度是必要的。
2) 等價於 return iterator<true>(ranges::begin(base_), n_);

目錄

[編輯] 引數

(無)

[編輯] 返回值

一個指向 slide_view 首元素的迭代器,它指向底層檢視型別中大小為 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 返回的迭代器
(函式) [編輯]