Namespaces
Variants

std::ranges::subrange<I,S,K>:: size

From cppreference.net
Ranges library
Range adaptors
constexpr /*make-unsigned-like-t*/ < std:: iter_difference_t < I >> size ( ) const
requires ( K == ranges :: subrange_kind :: sized ) ;
(depuis C++20)
Seules les parties suivantes ont été traduites : - "(since C++20)" → "(depuis C++20)" Tous les autres éléments (balises HTML, code C++, termes techniques) ont été conservés dans leur forme originale comme demandé.

Obtient le nombre d'éléments dans le subrange :

Pour la définition de /*make-unsigned-like-t*/ , voir make-unsigned-like-t .

Valeur de retour

Comme décrit ci-dessus.

Exemple

#include <functional>
#include <iostream>
#include <ranges>
#include <utility>
int main()
{
    const auto v = {2, 2, 2, 7, 1, 1, 1, 1, 8, 2, 2, 2, 2, 2};
    // le type de valeur de views::chunk_by est le ranges::subrange
    auto to_pair = [](auto sub) { return std::make_pair(sub[0], sub.size()); };
                                                                 /* ^^^^ */
    auto pairs = v | std::views::chunk_by(std::equal_to{})
                   | std::views::transform(to_pair);
    for (auto x : pairs bitor std::views::keys)
        std::cout << x << ' ';
    std::cout << '\n';
    for (auto x : pairs bitor std::views::values)
        std::cout << x << ' ';
    std::cout << '\n';
}

Sortie :

2 7 1 8 2
3 1 4 1 5

Voir aussi

vérifie si le subrange est vide
(fonction membre publique)
(C++17) (C++20)
retourne la taille d'un conteneur ou d'un tableau
(modèle de fonction)
retourne un entier égal à la taille d'une plage
(objet de point de personnalisation)