Namespaces
Variants

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

From cppreference.net
Ranges library
Range adaptors
constexpr auto begin ( ) requires ( ! __SimpleView < V > ) ;
(1) (depuis C++23)
constexpr auto begin ( ) const requires ranges:: range < const V > ;
(2) (depuis C++23)

Retourne un itérateur vers le premier élément de la adjacent_view .

Soit base_ la vue sous-jacente.

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

Table des matières

Paramètres

(aucun)

Valeur de retour

Itérateur vers le premier élément.

Exemple

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

Voir aussi

retourne un itérateur ou un sentinelle vers la fin
(fonction membre publique)
retourne un itérateur vers le début d'une plage
(objet de point de personnalisation)