std::ranges::drop_view<V>::size
De cppreference.com
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
Ejecuta este código
#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
(C++20) |
Obtiene el tamaño de un rango cuyo tamaño puede calcularse en tiempo constante. (objeto punto de personalización) |
(C++20) |
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) |