std::ranges::subrange<I,S,K>:: size
From cppreference.net
C++
Ranges library
|
||||||||||||||||||||||
| Range primitives | |||||||
|
|||||||
| Range concepts | |||||||||||||||||||
|
|||||||||||||||||||
| Range factories | |||||||||
|
|||||||||
| Range adaptors | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||
| Helper items | |||||||||||||||||
|
|
||||||||||||||||
std::ranges::subrange
|
constexpr
/*make-unsigned-like-t*/
<
std::
iter_difference_t
<
I
>>
size
(
)
const
requires ( K == ranges :: subrange_kind :: sized ) ; |
(depuis C++20) | |
Obtient le nombre d'éléments dans le
subrange
:
-
Si
StoreSizeest true , retournesize_. -
Sinon, retourne
to-unsigned-like (end_-begin_ ) .
Pour la définition de
/*make-unsigned-like-t*/
, voir
make-unsigned-like-t
.
Valeur de retour
Comme décrit ci-dessus.
Exemple
Exécuter ce code
#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) |
|
(C++20)
|
retourne un entier égal à la taille d'une plage
(objet de point de personnalisation) |