Namespaces
Variants

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

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

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

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

Gibt einen Iterator oder std::default_sentinel zurück, der dem Past-the-End-Iterator des concat_view entspricht.

1) Entspricht

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) Entspricht

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 ;

.

Rückgabewert

Wie oben beschrieben.

Beispiel

Die Vorabversion kann auf Compiler Explorer eingesehen werden.

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

Siehe auch

gibt einen Iterator zum Anfang zurück
(öffentliche Elementfunktion)
gibt einen Sentinel zurück, der das Ende eines Bereichs anzeigt
(Anpassungspunktobjekt)