std::ranges::split_view<V,Pattern>::begin
Von cppreference.com
< cpp | ranges | split view
| 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
Führen Sie diesen Code aus
#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) | |
| gibt einen Iterator zum Anfang zurück (öffentliche Member-Funktion von std::ranges::lazy_split_view<V,Pattern>) | |
| (C++20) |
gibt einen Iterator zum Anfang eines Ranges zurück (Customization Point Objekt) |