Namensräume
Varianten
Aktionen

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

Von cppreference.com
< cpp‎ | ranges‎ | split view
 
 
Bereichsbibliothek
Range-Adaptoren
 
 
constexpr /*iterator*/ begin();
(seit C++20)

Gibt einen Iterator zum ersten gefundenen Unterbereich zurück.

Um die vom range-Konzept geforderte amortisierte konstante Zeitkomplexität zu bieten, speichert diese Funktion das Ergebnis innerhalb der split_view (mittels des cached_begin_-Members) für nachfolgende Aufrufe.

Sei base_ das zugrundeliegende Datenelement. Äquivalent zu

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

Inhalt

[bearbeiten] Rückgabewert

Ein Iterator.

[bearbeiten] Komplexität

Amortisiert O(1).

[bearbeiten] Beispiel

#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';
}

Ausgabe

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 . .

[bearbeiten] Siehe auch

gibt einen Iterator oder Sentinel zum Ende zurück
(öffentliche Member-Funktion) [edit]
gibt einen Iterator zum Anfang zurück
(öffentliche Member-Funktion von std::ranges::lazy_split_view<V,Pattern>) [bearbeiten]
gibt einen Iterator zum Anfang eines Ranges zurück
(Customization Point Objekt)[edit]