Namespaces
Variants

std::ranges::zip_transform_view<F,Views...>:: size

From cppreference.net
Ranges library
Range adaptors
constexpr auto size ( )
requires ranges:: sized_range < /*InnerView*/ > ;
(1) (desde C++23)
constexpr auto size ( ) const
requires ranges:: sized_range < const /*InnerView*/ >
(2) (desde C++23)

Devuelve el número de elementos en el zip_transform_view . Se proporciona solo si cada rango subyacente (adaptado) satisface sized_range .

1,2) Equivalente a: return zip_ . size ( ) ; .

Contenidos

Parámetros

(ninguno)

Valor de retorno

El número de elementos, que es el tamaño mínimo entre todos los tamaños de las view s adaptadas.

Ejemplo

#include <algorithm>
#include <cassert>
#include <deque>
#include <forward_list>
#include <functional>
#include <iostream>
#include <ranges>
#include <vector>
int main()
{
    auto x = std::vector{1, 2, 3, 4, 5};
    auto y = std::deque<short>{10, 20, 30};
    auto z = std::forward_list{100., 200.};
    auto v1 = std::views::zip_transform(std::plus{}, x, y);
    assert(v1.size() == std::min(x.size(), y.size()));
    assert(v1.size() == 3);
    for (int i : v1)
        std::cout << i << ' ';
    std::cout << '\n';
    [[maybe_unused]] auto v2 = std::views::zip_transform(std::plus{}, x, z);
//  auto sz = v2.size(); // Error: z doesn't have size(), so neither does v2
    static_assert(not std::ranges::sized_range<decltype(z)>);
}

Salida:

11 22 33

Véase también

devuelve un entero igual al tamaño de un rango
(objeto de punto de personalización)
devuelve un entero con signo igual al tamaño de un rango
(objeto de punto de personalización)