std::ranges::views:: all, std::ranges::views:: all_t
From cppreference.net
|
Definiert im Header
<ranges>
|
||
|
inline
constexpr
/* unspecified */
all
=
/* unspecified */
;
|
(1) | (seit C++20) |
|
template
<
ranges::
viewable_range
R
>
using all_t = decltype ( views :: all ( std:: declval < R > ( ) ) ) ; |
(2) | (seit C++20) |
1)
Ein
RangeAdaptorObject
(auch ein
RangeAdaptorClosureObject
), der eine
view
zurückgibt, die alle Elemente ihres
range
-Arguments enthält.
Gegeben einen Ausdruck
e
vom Typ
R
, ist der Ausdruck
views
::
all
(
e
)
ausdrucksäquivalent
zu:
-
Falls
std::
decay_t
<
R
>
das Konzept
viewmodelliert, implizite Konvertierung von e zu einem std:: decay_t < R > Prvalue. - Andernfalls std :: ranges:: ref_view { e } , falls dieser Ausdruck wohlgeformt ist.
- Andernfalls std :: ranges:: owning_view { e } .
Beispiel
Diesen Code ausführen
#include <iostream> #include <ranges> #include <type_traits> #include <vector> int main() { std::vector<int> v{0, 1, 2, 3, 4, 5}; for (int n : std::views::all(v) | std::views::take(2)) std::cout << n << ' '; std::cout << '\n'; static_assert(std::is_same< decltype(std::views::single(42)), std::ranges::single_view<int> >{}); static_assert(std::is_same< decltype(std::views::all(v)), std::ranges::ref_view<std::vector<int, std::allocator<int>>> >{}); int a[]{1, 2, 3, 4}; static_assert(std::is_same< decltype(std::views::all(a)), std::ranges::ref_view<int[4]> >{}); static_assert(std::is_same< decltype(std::ranges::subrange{std::begin(a) + 1, std::end(a) - 1}), std::ranges::subrange<int*, int*, std::ranges::subrange_kind(1)> >{}); }
Ausgabe:
0 1
Fehlerberichte
Die folgenden verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.
| DR | Angewendet auf | Verhalten wie veröffentlicht | Korrektes Verhalten |
|---|---|---|---|
| LWG 3724 | C++20 |
views::all
könnte zu schweren Fehlern für einige move-only Views führen
|
wird gut eingeschränkt |
| P2415R2 | C++20 |
views::all
lieferte einen
subrange
für einen nicht-
view
Rvalue-
range
|
liefert einen
owning_view
dafür
|
Siehe auch
|
(C++20)
|
eine leere
view
ohne Elemente
(Klassen-Template) (Variablen-Template) |
eine
view
die ein einzelnes Element eines bestimmten Wertes enthält
(Klassen-Template) (Customization Point Object) |
|
|
(C++20)
|
eine
view
mit eindeutigem Besitz eines
range
(Klassen-Template) |