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 modélise uniquement input_range
constexpr std:: default_sentinel_t end ( ) const noexcept ;
(1) (depuis C++23)
V modélise forward_range
constexpr auto end ( ) requires ( ! __simple_view < V > ) ;
(2) (depuis C++23)
constexpr auto end ( ) const requires ranges:: forward_range < const V > ;
(3) (depuis C++23)

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

1) Disponible uniquement si V modélise input_range . Équivalent à : return std:: default_sentinel .
2,3) Disponible si V modélise forward_range . Soit base_ la vue adaptée sous-jacente, n_ la taille de chunk stockée, et iterator la classe d'itérateur imbriquée.
2) Équivalent à
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) Équivalent à
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;

Valeur de retour

Un itérateur ou sentinelle représentant la fin de la chunk_view , comme décrit ci-dessus.

Exemple

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)