std::ranges::slide_view<V>::size
Von cppreference.com
< cpp | ranges | slide view
| constexpr auto size() requires ranges::sized_range<V>; |
(1) | (seit C++23) |
| constexpr auto size() const requires ranges::sized_range<const V>; |
(2) | (seit C++23) |
Gibt die Anzahl der Elemente zurück.
Seien base_ und n_ die zugrundeliegende View und die „Fenstergröße“ bzw. die Anzahl der Elemente. Äquivalent zu
auto sz = ranges::distance(base_) - n_ + 1; if (sz < 0) sz = 0; return /*to-unsigned-like*/(sz);
[bearbeiten] Rückgabewert
Die Anzahl der Elemente. Gleich 0, wenn die Anzahl der Elemente (ranges::size(base_)) in der zugrundeliegenden View base_ kleiner ist als die „Fenstergröße“ n_.
[bearbeiten] Beispiel
Führen Sie diesen Code aus
#include <forward_list> #include <iostream> #include <list> #include <ranges> int main() { constexpr static auto v = {1, 2, 3, 4, 5, 6}; constexpr int width1{4}; constexpr auto view1{std::views::slide(v, width1)}; static_assert(view1.size() == 3); static_assert(view1.size() == (v.size() - width1 + 1)); constexpr int width2{8}; constexpr auto view2{std::views::slide(v, width2)}; // window is too wide, so view2 has no elements: static_assert(view2.size() == 0); std::forward_list forward_list = v; const auto view3{std::views::slide(forward_list, width1)}; // auto x = view3.size(); // error: sized_range constraint is not satisfied std::list list = v; const auto view4{std::views::slide(list, width1)}; std::cout << view4.size() << '\n'; // prints 3 }
Ausgabe
3
[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) |