Namespaces
Variants

std::ranges::chunk_view<V>:: end

From cppreference.net
Ranges library
Range adaptors
std::ranges::chunk_view
Member functions
chunk_view::end
Classes for input_range s
Deduction guides
outer-iterator
outer-iterator ::value_type
inner-iterator
V modelliert nur input_range
constexpr std:: default_sentinel_t end ( ) const noexcept ;
(1) (seit C++23)
V modelliert forward_range
constexpr auto end ( ) requires ( ! __simple_view < V > ) ;
(2) (seit C++23)
constexpr auto end ( ) const requires ranges:: forward_range < const V > ;
(3) (seit C++23)

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

1) Nur verfügbar, wenn V das Konzept input_range modelliert. Äquivalent zu: return std:: default_sentinel .
2,3) Verfügbar, falls V das Konzept forward_range modelliert. Sei base_ die zugrundeliegende adaptierte View, n_ die gespeicherte Chunk-Größe und iterator die geschachtelte Iterator-Klasse.
2) Entspricht
if constexpr (ranges::common_range<V> && ranges::sized_range<V>)
{
    auto missing = (n_ - ranges::distance(base_) % n_) % n_;
    return iterator<false>(this, ranges::end(base_), missing);
}
else if constexpr (ranges::common_range<V> && !ranges::bidirectional_range<V>)
    return iterator<false>(this, ranges::end(base_));
else
    return std::default_sentinel;
3) Entspricht
if constexpr (ranges::common_range<const V> && ranges::sized_range<const V>)
{
    auto missing = (n_ - ranges::distance(base_) % n_) % n_;
    return iterator<true>(this, ranges::end(base_), missing);
}
else if constexpr (ranges::common_range<const V> && !ranges::bidirectional_range<const V>)
    return iterator<true>(this, ranges::end(base_));
else
    return std::default_sentinel;

Rückgabewert

Ein Iterator oder Sentinel, der das Ende der chunk_view repräsentiert, wie oben beschrieben.

Beispiel

Siehe auch

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