Namespaces
Variants

std::ranges::slide_view<V>:: begin

From cppreference.net
Ranges library
Range adaptors
constexpr auto begin ( )
requires ( ! ( /*simple-view*/ < V > && /*slide-caches-nothing*/ < const V > ) ) ;
(1) (seit C++23)
constexpr auto begin ( ) const
requires /*slide-caches-nothing*/ < const V > ;
(2) (seit C++23)

Gibt einen Iterator zum ersten Element des slide_view zurück.

1) Wenn V das Konzept slide-caches-first modelliert, entspricht dies
Andernfalls äquivalent zu return iterator < false > ( ranges:: begin ( base_ ) , n_ ) ; .
Wenn V das Konzept slide-caches-first modelliert, speichert diese Funktion das Ergebnis im cached_begin_ für nachfolgende Aufrufe zwischen. Dies ist erforderlich, um die amortisierte konstante Zeitkomplexität bereitzustellen, die vom range gefordert wird.
2) Entspricht return iterator < true > ( ranges:: begin ( base_ ) , n_ ) ; .

Inhaltsverzeichnis

Parameter

(keine)

Rückgabewert

Ein Iterator zum ersten Element des slide_view , der auf den n_ -großen Subbereich des zugrundeliegenden View-Typs zeigt: V für Überladung ( 1 ) oder const V für Überladung ( 2 ) .

Beispiel

#include <iostream>
#include <ranges>
#include <string_view>
using namespace std::literals;
int main()
{
    static constexpr auto source = {"∀x"sv, "∃y"sv, "ε"sv, "δ"sv};
    auto view{std::ranges::slide_view(source, 2)};
    const auto subrange{*(view.begin())};
    for (std::string_view const s : subrange)
        std::cout << s << ' ';
    std::cout << '\n';
}

Ausgabe:

∀x ∃y

Siehe auch

gibt einen Iterator oder Sentinel zum Ende zurück
(öffentliche Elementfunktion)
(C++23)
vergleicht einen Sentinel mit einem von slide_view::begin zurückgegebenen Iterator
(Funktion)