Namensräume
Varianten
Aktionen

std::ranges::rend

Von cppreference.com
< cpp‎ | ranges
 
 
Bereichsbibliothek
Range-Adaptoren
 
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 */
constexpr std::sentinel_for<

    decltype(ranges::rbegin(std::declval<T>()))> auto rend( T&& t );
(seit C++20)

Gibt ein Sentinel zurück, das das Ende eines umgekehrten Bereichs angibt.

range-rbegin-rend.svg

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

  1. 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.
  2. Andernfalls decay-copy(rend(t))(bis C++23)auto(rend(t))(seit C++23), wenn T ein 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 von rend durch eine Argument-abhängige Suche (ADL) etabliert wird.
  3. 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

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

gibt einen Reverse-End-Iterator zu einem schreibgeschützten Range zurück
(Customization Point Objekt)[edit]
gibt einen Reverse-Iterator zu einem Range zurück
(Customization Point Objekt)[edit]
(C++14)
gibt einen Reverse-End-Iterator für einen Container oder ein Array zurück
(function template) [bearbeiten]