std::ranges::subrange<I,S,K>::size
Von cppreference.com
| constexpr /*make-unsigned-like-t*/<std::iter_difference_t<I>> size() const requires (K == ranges::subrange_kind::sized); |
(seit C++20) | |
Ermittelt die Anzahl der Elemente im subrange
- Wenn
StoreSizeist true, gibtsize_zurück. - Andernfalls gibt
to-unsigned-like(end_-begin_) zurück.
Für die Definition von /*make-unsigned-like-t*/ siehe make-unsigned-like-t .
[bearbeiten] Rückgabewert
Wie oben beschrieben.
[bearbeiten] Beispiel
Führen Sie diesen Code aus
#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}; // the value type of views::chunk_by is the 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'; }
Ausgabe
2 7 1 8 2 3 1 4 1 5
[bearbeiten] Siehe auch
prüft, ob der subrange leer ist(public member function) | |
| (C++17)(C++20) |
gibt die Größe eines Containers oder Arrays zurück (Funktionsvorlage) |
| (C++20) |
gibt eine Ganzzahl zurück, die der Größe eines Ranges entspricht (Customization Point Objekt) |