std::ranges::zip_view<Views...>:: size
From cppreference.net
C++
Ranges library
|
||||||||||||||||||||||
| Range primitives | |||||||
|
|||||||
| Range concepts | |||||||||||||||||||
|
|||||||||||||||||||
| Range factories | |||||||||
|
|||||||||
| Range adaptors | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||
| Helper items | |||||||||||||||||
|
|
||||||||||||||||
std::ranges::zip_view
| Member functions | ||||
|
zip_view::size
|
||||
| Deduction guides | ||||
| Iterator | ||||
| Member functions | ||||
| Non-member functions | ||||
| Sentinel | ||||
| Member functions | ||||
| Non-member functions | ||||
|
constexpr
auto
size
(
)
requires ( ranges:: sized_range < Views > && ... ) ; |
(1) | (depuis C++23) |
|
constexpr
auto
size
(
)
const
requires ( ranges:: sized_range < const Views > && ... ) ; |
(2) | (depuis C++23) |
Retourne le nombre d'éléments dans le
zip_view
. Fourni uniquement si chaque plage sous-jacente (adaptée) satisfait
sized_range
.
Équivalent à :
return std::apply ( [](auto... sizes) { using CT = /*make-unsigned-like-t*/<std::common_type_t<decltype(sizes)...>>; return ranges::min({CT(sizes)...}); }, /*tuple-transform*/(ranges::size, views_) );
Table des matières |
Paramètres
(aucun)
Valeur de retour
Le nombre d'éléments, qui est la taille minimale parmi toutes les tailles des
view
s
adaptées.
Exemple
Exécuter ce code
#include <algorithm> #include <cassert> #include <deque> #include <forward_list> #include <ranges> #include <vector> int main() { auto x = std::vector{1, 2, 3, 4, 5}; auto y = std::deque{'a', 'b', 'c'}; auto z = std::forward_list{1., 2.}; auto v1 = std::views::zip(x, y); assert(v1.size() == std::min(x.size(), y.size())); assert(v1.size() == 3); [[maybe_unused]] auto v2 = std::views::zip(x, z); // auto sz = v2.size(); // Erreur, v2 n'a pas de size() : static_assert(not std::ranges::sized_range<decltype(z)>); }
Voir aussi
|
(C++20)
|
renvoie un entier égal à la taille d'une plage
(objet point de personnalisation) |
|
(C++20)
|
renvoie un entier signé égal à la taille d'une plage
(objet point de personnalisation) |