Espacios de nombres
Variantes

std::ranges::drop_view<V>::size

De cppreference.com
 
 
Biblioteca de rangos
Adaptadores de rangos
 
 
constexpr auto size() requires ranges::sized_range<V>;
(1) (desde C++20)
constexpr auto size() const requires ranges::sized_range<const V>;
(2) (desde C++20)

Devuelve el número de elementos.

Sea base_ la vista subyacente y count_ la cuenta almacenada (habitualmente el número pasado al constructor, o 0 si *this si se construyó por defecto). Equivalente a

const auto s = ranges::size(base_);
const auto c = static_cast<decltype(s)>(count_);
return s < c ? 0 : s - c;

Parámetros

(Ninguno)

Valor de retorno

El número de elementos.

Ejemplo

#include <array>
#include <ranges>

int main()
{
    constexpr std::array a{42, 43, 44};
    static_assert(std::ranges::drop_view{std::views::all(a), 0}.size() == 3);
    static_assert(std::ranges::drop_view{std::views::all(a), 1}.size() == 2);
    static_assert(std::ranges::drop_view{std::views::all(a), 2}.size() == 1);
    static_assert(std::ranges::drop_view{std::views::all(a), 3}.size() == 0);
    static_assert(std::ranges::drop_view{std::views::all(a), 4}.size() == 0);
}


Véase también

Obtiene el tamaño de un rango cuyo tamaño puede calcularse en tiempo constante.
(objeto punto de personalización) [editar]
Obtiene el tamaño de un rango cuyo tamaño puede calcularse en tiempo constante y lo convierte a un entero con signo.
(objeto punto de personalización) [editar]