Namensräume
Varianten
Aktionen

std::ranges::adjacent_view<V,N>::begin

Von cppreference.com
 
 
Bereichsbibliothek
Range-Adaptoren
 
 
constexpr auto begin() requires (!__SimpleView<V>);
(1) (seit C++23)
constexpr auto begin() const requires ranges::range<const V>;
(2) (seit C++23)

Gibt einen Iterator zum ersten Element der adjacent_view zurück.

Sei base_ die zugrunde liegende View.

1) Äquivalent zu return /*iterator*/<false>(ranges::begin(base_), ranges::end(base_));.
2) Äquivalent zu return /*iterator*/<true>(ranges::begin(base_), ranges::end(base_));.

Inhalt

[edit] Parameter

(keine)

[edit] Rückgabewert

Iterator zum ersten Element.

[edit] Beispiel

#include <ranges>
#include <tuple>
#include <type_traits>
 
int main()
{
    constexpr static auto v = {'A', 'B', 'C', 'D', 'E'};
 
    constexpr auto view = std::views::adjacent<3>(v);
 
    constexpr auto tuple = *view.begin();
 
    static_assert
    (
        std::is_same_v
        <
            decltype(tuple),
            const std::tuple<char const&, char const&, char const&>
        >
    );
 
    static_assert
    (
        std::get<0>(tuple) == 'A' &&
        std::get<1>(tuple) == 'B' &&
        std::get<2>(tuple) == 'C'
    );
}

[edit] Siehe auch

gibt einen Iterator oder Sentinel zum Ende zurück
(öffentliche Member-Funktion) [edit]
gibt einen Iterator zum Anfang eines Ranges zurück
(Customization Point Objekt)[edit]