std::ranges::rend
| Definiert in der Header-Datei <ranges> |
||
| Definiert in Header <iterator> |
||
| inline namespace /* nicht spezifiziert */ { inline constexpr /* nicht spezifiziert */ rend = /* nicht spezifiziert */; |
(seit C++20) (Customization-Point-Objekt) |
|
| Aufruf-Signatur |
||
| template< class T > requires /* siehe unten */ |
(seit C++20) | |
Gibt ein Sentinel zurück, das das Ende eines umgekehrten Bereichs angibt.
Wenn T ein Array-Typ ist und std::remove_all_extents_t<std::remove_reference_t<T>> unvollständig ist, ist der Aufruf von ranges::rend nicht wohlgeformt, ohne Diagnose.
Wenn das Argument ein lvalue ist oder ranges::enable_borrowed_range<std::remove_cv_t<T>> true ist, dann ist ein Aufruf von ranges::rend ausdrucksäquivalent zu
- decay-copy(t.rend())(bis C++23)auto(t.rend())(seit C++23), wenn dieser Ausdruck gültig ist und sein Typ std::sentinel_for<decltype(ranges::rbegin(std::declval<T>()))> modelliert.
- Andernfalls decay-copy(rend(t))(bis C++23)auto(rend(t))(seit C++23), wenn
Tein Klassen- oder Aufzählungstyp ist, dieser Ausdruck gültig ist und sein Typ std::sentinel_for<decltype(ranges::rbegin(std::declval<T>()))> modelliert, wobei die Bedeutung vonrenddurch eine Argument-abhängige Suche (ADL) etabliert wird. - Andernfalls std::make_reverse_iterator(ranges::begin(t)), wenn sowohl ranges::begin(t) als auch ranges::end(t) gültige Ausdrücke sind, denselben Typ haben und dieser Typ std::bidirectional_iterator modelliert.
In allen anderen Fällen ist ein Aufruf von ranges::rend nicht wohlgeformt, was zu einem Substitutionsfehler führen kann, wenn ranges::rend(t) im unmittelbaren Kontext einer Template-Instanziierung auftritt.
Inhalt |
Customization Point Objects
Der Name ranges::rend bezeichnet ein Customization Point Object, ein konstantes Funktionsobjekt vom Typ einer literalen semiregular-Klasse. Zu Demonstrationszwecken wird die cv-unqualifizierte Version seines Typs als __rend_fn bezeichnet.
Alle Instanzen von __rend_fn sind gleich. Die Effekte des Aufrufs verschiedener Instanzen vom Typ __rend_fn mit denselben Argumenten sind äquivalent, unabhängig davon, ob der Ausdruck, der die Instanz bezeichnet, ein lvalue oder rvalue ist und ob er const-qualifiziert ist oder nicht (eine volatile-qualifizierte Instanz muss jedoch nicht aufrufbar sein). Daher kann ranges::rend frei kopiert werden und seine Kopien können austauschbar verwendet werden.
Gegeben sei eine Menge von Typen Args.... Wenn std::declval<Args>()... die oben genannten Anforderungen für Argumente von ranges::rend erfüllt, modelliert __rend_fn
- std::invocable<__rend_fn, Args...>,
- std::invocable<const __rend_fn, Args...>,
- std::invocable<__rend_fn&, Args...>, und
- std::invocable<const __rend_fn&, Args...>.
Andernfalls nimmt kein operator() von __rend_fn an der Überladungsauflösung teil.
[bearbeiten] Anmerkungen
Wenn das Argument ein rvalue ist (d.h. T ein Objekttyp ist) und ranges::enable_borrowed_range<std::remove_cv_t<T>> false ist, oder wenn es von einem Array-Typ mit unbekannter Bindung ist, ist der Aufruf von ranges::rend nicht wohlgeformt, was ebenfalls zu einem Substitutionsfehler führt.
Wenn ranges::rend(std::forward<T>(t)) gültig ist, dann modellieren decltype(ranges::rend(std::forward<T>(t))) und decltype(ranges::begin(std::forward<T>(t))) std::sentinel_for in allen Fällen, während T std::ranges::range modelliert.
Der C++20-Standard verlangt, dass bei einem Rückgabewert von rend als prvalue dieser vom materialisierten temporären Objekt per Move-Konstruktion erstellt wird. Alle Implementierungen geben den prvalue direkt zurück. Die Anforderung wird durch den Post-C++20-Vorschlag P0849R8 korrigiert, um den Implementierungen zu entsprechen.
[bearbeiten] Beispiel
#include <algorithm> #include <iostream> #include <ranges> #include <vector> int main() { std::vector<int> v = {3, 1, 4}; namespace ranges = std::ranges; if (ranges::find(ranges::rbegin(v), ranges::rend(v), 5) != ranges::rend(v)) std::cout << "found a 5 in vector v!\n"; int a[] = {5, 10, 15}; if (ranges::find(ranges::rbegin(a), ranges::rend(a), 5) != ranges::rend(a)) std::cout << "found a 5 in array a!\n"; }
Ausgabe
found a 5 in array a!
[bearbeiten] Fehlerberichte
Die folgenden Verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.
| DR | angewendet auf | Verhalten wie veröffentlicht | Korrigiertes Verhalten |
|---|---|---|---|
| P2602R2 | C++20 | Es gibt Mechanismen, um bestimmte Nicht-Member-rend zu verbieten, die durch ADL gefunden werden. |
solche Mechanismen wurden entfernt. |
[bearbeiten] Siehe auch
| (C++20) |
gibt einen Reverse-End-Iterator zu einem schreibgeschützten Range zurück (Customization Point Objekt) |
| (C++20) |
gibt einen Reverse-Iterator zu einem Range zurück (Customization Point Objekt) |
| (C++14) |
gibt einen Reverse-End-Iterator für einen Container oder ein Array zurück (function template) |