Namespaces
Variants

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

From cppreference.net
Ranges library
Range adaptors
constexpr /*iterator*/ begin ( ) ;
(C++20부터)

첫 번째로 발견된 부분 범위에 대한 iterator 를 반환합니다.

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()};
}

목차

반환값

iterator 입니다.

복잡도

분할 상환 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()})
              << "\nSubstrings: ";
    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()})
              << "\nLetters: ";
    for (auto letter : letters)
        std::cout << std::string_view(letter) << ' ';
    std::cout << '\n';
}

출력:

begin(): "Keep"
Substrings: "Keep" "moving" "forward" ""
begin(): "K"
Letters: K e e p . . m o v i n g . . f o r w a r d . .

참고 항목

끝을 가리키는 반복자나 센티널을 반환합니다
(public member function)
시작을 가리키는 반복자를 반환합니다
( std::ranges::lazy_split_view<V,Pattern> 의 public member function)
범위의 시작을 가리키는 반복자를 반환합니다
(customization point object)