std::ranges::split_view<V,Pattern>::begin

出自cppreference.com
< cpp‎ | ranges‎ | split view
 
 
範圍庫
範圍適配器
 
 
constexpr /*iterator*/ begin();
(C++20 起)

返回指向找到的第一個子範圍的迭代器

為提供 range 概念要求的均攤常數複雜度,此函數在 split_view 中緩存了結果(通過 cached_begin_ 成員)以供後續調用所用。

base_ 作為底層數據成員。等價於:

constexpr /*iterator*/ begin()
{
    if (!cached_begin_.has_value())
        cached_begin_ = this->find_next(ranges::begin(base_));
    return {*this, ranges::begin(base_), cached_begin_.value()};
}

目錄

[編輯] 返回值

迭代器

[編輯] 複雜度

均攤的 O(1)

[編輯] 示例

#include <iomanip>
#include <iostream>
#include <ranges>
#include <string_view>
 
int main()
{
    constexpr std::string_view sentence{"Keep..moving..forward.."};
    constexpr std::string_view delim{".."};
    std::ranges::split_view words{sentence, delim};
 
    std::cout << "begin(): " << std::quoted(std::string_view{*words.begin()})
              << "\n子字符串: ";
    for (auto word : words)
        std::cout << std::quoted(std::string_view(word)) << ' ';
 
    std::ranges::split_view letters{sentence, std::string_view{""}};
    std::cout << "\nbegin(): " << std::quoted(std::string_view{*letters.begin()})
              << "\n字母: ";
    for (auto letter : letters)
        std::cout << std::string_view(letter) << ' ';
    std::cout << '\n';
}

輸出:

begin(): "Keep"
子字符串: "Keep" "moving" "forward" ""
begin(): "K"
字母: K e e p . . m o v i n g . . f o r w a r d . .

[編輯] 參閱

返回 指向末尾的迭代器或哨位
(公開成員函數) [編輯]
返回指向起始的迭代器
(std::ranges::lazy_split_view<V,Pattern> 的公開成員函數) [編輯]
返回指向範圍起始的迭代器
(定製點對象) [編輯]