Namespaces
Variants

std::ranges::concat_view<Views...>:: end

From cppreference.net
Ranges library
Range adaptors
constexpr auto end ( )
requires ( ! ( /*simple-view*/ < Views > && ... ) ) ;
(1) (depuis C++26)
constexpr auto end ( ) const

requires ( ranges:: range < const Views > && ... ) &&

/*concatable*/ < const Views... > ;
(2) (depuis C++26)

Retourne un itérateur ou std::default_sentinel qui compare égal à l'itérateur de fin de la concat_view .

1) Équivalent à

constexpr auto N = sizeof... ( Views ) ;
if constexpr ( ranges:: common_range < Views... [ N - 1 ] > )
return iterator  < false > ( this, std:: in_place_index < N - 1 > ,
ranges:: end ( std :: get < N - 1 > ( views_  ) ) ) ;
else
return std:: default_sentinel ;

.
2) Équivalent à

constexpr auto N = sizeof... ( Views ) ;
if constexpr ( ranges:: common_range < const Views... [ N - 1 ] > )
return iterator  < true > ( this, std:: in_place_index < N - 1 > ,
ranges:: end ( std :: get < N - 1 > ( views_  ) ) ) ;
else
return std:: default_sentinel ;

.

Valeur de retour

Comme décrit ci-dessus.

Exemple

La version préliminaire peut être consultée sur Compiler Explorer .

#include <concepts>
#include <iterator>
#include <ranges>
int main()
{
    static constexpr int p[]{37, 42, 69};
    static constexpr auto q = {19937, 1729};
    constexpr auto cat = std::ranges::views::concat(p, q);
    static_assert(not std::same_as<std::default_sentinel_t, decltype(cat.end())>);
    static_assert(cat.end()[-1] == 1729);
}

Voir aussi

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