std::ranges::cartesian_product_view<First, Vs...>:: size
|
||||||||||||||||||||||
| Range primitives | |||||||
|
|||||||
| Range concepts | |||||||||||||||||||
|
|||||||||||||||||||
| Range factories | |||||||||
|
|||||||||
| Range adaptors | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||
| Helper items | |||||||||||||||||
|
|
||||||||||||||||
| Member functions | ||||
|
cartesian_product_view::size
|
||||
| Deduction guides | ||||
| Iterator | ||||
| Member functions | ||||
| Non-member functions | ||||
|
constexpr
/* siehe Beschreibung */
size
(
)
requires /*cartesian-product-is-sized*/ < First, Vs... > ; |
(1) | (seit C++23) |
|
constexpr
/* siehe Beschreibung */
size
(
)
const
requires /*cartesian-product-is-sized*/ < const First, const Vs... > ; |
(2) | (seit C++23) |
Gibt die Anzahl der Elemente zurück. Der Rückgabetyp ist ein implementierungsdefinierter /*unsigned-integer-like*/ Typ U .
Sei
bases_
das zugrundeliegende Tupel von Views, und
prod
das Produkt der Größen aller Bereiche in
bases_
.
Entspricht:
return [&]<std::size_t... Is>(std::index_sequence<Is...>) { auto prod = static_cast<U>(1); prod = (static_cast<U>(ranges::size(std::get<Is>(bases_))) * ...); return prod; } (std::make_index_sequence<1U + sizeof...(Vs)>{});
Inhaltsverzeichnis |
Parameter
(keine)
Rückgabewert
Die Anzahl der Elemente, also das Produkt der Größen aller zugrundeliegenden Bereiche.
Hinweise
Der Rückgabetyp ist der kleinste /*unsigned-integer-like*/ Typ, der breit genug ist, um das Produkt der maximalen Größen aller zugrundeliegenden Bereiche zu speichern, falls ein solcher Typ existiert.
Beispiel
#include <ranges> int main() { constexpr static auto w = {1}; constexpr static auto x = {2, 3}; constexpr static auto y = {4, 5, 6}; constexpr static auto z = {7, 8, 9, 10, 11, 12, 13}; constexpr auto v = std::ranges::cartesian_product_view(w, x, y, z); static_assert(v.size() == w.size() * x.size() * y.size() * z.size() and v.size() == 42); }
Siehe auch
|
(C++20)
|
gibt einen ganzzahligen Wert zurück, der der Größe eines Ranges entspricht
(Anpassungspunktobjekt) |
|
(C++20)
|
gibt einen vorzeichenbehafteten ganzzahligen Wert zurück, der der Größe eines Ranges entspricht
(Anpassungspunktobjekt) |