std::ranges::zip_transform_view<F,Views...>:size
Von cppreference.com
< cpp | ranges | zip transform view
| constexpr auto size() requires ranges::sized_range</*InnerView*/>; |
(1) | (seit C++23) |
| constexpr auto size() const requires ranges::sized_range<const /*InnerView*/> |
(2) | (seit C++23) |
Gibt die Anzahl der Elemente in der zip_transform_view zurück. Wird nur bereitgestellt, wenn jeder zugrunde liegende (angepasste) Bereich sized_range erfüllt.
1,2) Äquivalent zu: return
zip_.size();.Inhalt |
[bearbeiten] Parameter
(keine)
[bearbeiten] Rückgabewert
Die Anzahl der Elemente, was der minimalen Größe aller Größen der angepassten views ist.
[bearbeiten] Beispiel
Führen Sie diesen Code aus
#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)>); }
Ausgabe
11 22 33
[bearbeiten] Siehe auch
| (C++20) |
gibt eine Ganzzahl zurück, die der Größe eines Ranges entspricht (Customization Point Objekt) |
| (C++20) |
gibt eine vorzeichenbehaftete Ganzzahl zurück, die der Größe eines Ranges entspricht (Customization Point Objekt) |