Namespaces
Variants

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

From cppreference.net
Ranges library
Range adaptors
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()};
}

Содержание

Возвращаемое значение

Итератор 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()})
              << "\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> )
возвращает итератор к началу диапазона
(объект точки настройки)