Namensräume
Varianten
Aktionen

std::ranges::stride_view<V>::size

Von cppreference.com
< cpp‎ | ranges‎ | stride view
 
 
Bereichsbibliothek
Range-Adaptoren
 
 
constexpr auto size() requires ranges::sized_range<V>;
(seit C++23)
constexpr auto size() const requires ranges::sized_range<const V>;
(seit C++23)

Gibt die Anzahl der Elemente zurück.

Sei base_ die zugrundeliegende View und stride_ der gespeicherte Schrittwert. Äquivalent zu

return /*to-unsigned-like*/(/*div-ceil*/(ranges::distance(base_), stride_));

Inhalt

[bearbeiten] Parameter

(keine)

[bearbeiten] Rückgabewert

Die Anzahl der Elemente. Der zurückgegebene Wert wird wie durch den Ausdruck berechnet

(ranges::size(base_) / stride_) + ((ranges::size(base_) % stride_ ? 1 : 0).

[bearbeiten] Beispiel

#include <forward_list>
#include <ranges>
 
int main()
{
    namespace vs = std::views;
    constexpr static auto v = {1, 2, 3, 4, 5};
    static_assert
    (
        vs::stride(v, 1).size() == 5 and
        vs::stride(v, 2).size() == 3 and
        vs::stride(v, 3).size() == 2 and
        vs::stride(v, 4).size() == 2 and
        vs::stride(v, 5).size() == 1 and
        vs::stride(v, 6).size() == 1
    );
 
    std::forward_list list{v};
//  auto s = vs::stride(list, 2).size(); // Error: not a sized_range
}

[bearbeiten] Siehe auch

gibt eine Ganzzahl zurück, die der Größe eines Ranges entspricht
(Customization Point Objekt)[edit]
gibt eine vorzeichenbehaftete Ganzzahl zurück, die der Größe eines Ranges entspricht
(Customization Point Objekt)[edit]