Namespaces
Variants

std::basic_stacktrace<Allocator>:: rend, std::basic_stacktrace<Allocator>:: crend

From cppreference.net
const_reverse_iterator rend ( ) const noexcept ;
(1) (depuis C++23)
const_reverse_iterator crend ( ) const noexcept ;
(2) (depuis C++23)

Retourne un itérateur inverse pointant après la dernière entrée du basic_stacktrace inversé. Il correspond à l'itérateur précédant la première entrée du basic_stacktrace original. Cet itérateur agit comme un marqueur, toute tentative de le déréférencer entraîne un comportement indéfini.

range-rbegin-rend.svg

Table des matières

Paramètres

(aucun)

Valeur de retour

L'itérateur de fin de la basic_stacktrace inversée.

Complexité

Constante.

Exemple

#include <algorithm>
#include <iostream>
#include <stacktrace>
int main()
{
    auto trace       = std::stacktrace::current();
    auto empty_trace = std::stacktrace{};
    // Afficher la trace d'exécution.
    std::for_each(trace.rbegin(), trace.rend(),
                  [](const auto& f) { std::cout << f << '\n'; });
    if (empty_trace.rbegin() == empty_trace.rend())
        std::cout << "La trace d'exécution 'empty_trace' est effectivement vide.\n";
}

Sortie possible :

0x0000000000402A29 in ./prog.exe
__libc_start_main in /lib/x86_64-linux-gnu/libc.so.6
0x0000000000402BA5 in ./prog.exe
La trace d'exécution 'empty_trace' est effectivement vide.

Voir aussi

retourne un itérateur inverse vers le début
(fonction membre publique)