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

Devuelve un iterador o un std::default_sentinel que compara igual al iterador final del chunk_view .

1) Disponible solo si V modela input_range . Equivalente a: return std:: default_sentinel .
2,3) Disponible si V modela forward_range . Sea base_ la vista adaptada subyacente, n_ el tamaño de fragmento almacenado, y iterator la clase iteradora anidada.
2) Equivalente a
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) Equivalente a
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;

Valor de retorno

Un iterador o centinela que representa el final de la chunk_view , como se describe anteriormente.

Ejemplo

Véase también

devuelve un iterador al inicio
(función miembro pública)
devuelve un centinela que indica el final de un rango
(objeto de punto de personalización)