Namensräume
Varianten
Aktionen

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

Von cppreference.com
 
 
 
 
const_reverse_iterator rend()  const noexcept;
(1) (seit C++23)
const_reverse_iterator crend() const noexcept;
(2) (seit C++23)

Gibt einen Reverse-Iterator zurück, der hinter dem letzten Eintrag des umgekehrten basic_stacktrace zeigt. Er entspricht dem Iterator, der dem ersten Eintrag des ursprünglichen basic_stacktrace vorangeht. Dieser Iterator dient als Platzhalter; der Versuch, ihn zu dereferenzieren, führt zu undefiniertem Verhalten.

range-rbegin-rend.svg

Inhalt

[bearbeiten] Parameter

(keine)

[bearbeiten] Rückgabewert

Der End-Iterator des umgekehrten basic_stacktrace.

[bearbeiten] Komplexität

Konstant.

[bearbeiten] Beispiel

#include <algorithm>
#include <iostream>
#include <stacktrace>
 
int main()
{
    auto trace       = std::stacktrace::current();
    auto empty_trace = std::stacktrace{};
 
    // Print stacktrace.
    std::for_each(trace.rbegin(), trace.rend(),
                  [](const auto& f) { std::cout << f << '\n'; });
 
    if (empty_trace.rbegin() == empty_trace.rend())
        std::cout << "stacktrace 'empty_trace' is indeed empty.\n";
}

Mögliche Ausgabe

0x0000000000402A29 in ./prog.exe
__libc_start_main in /lib/x86_64-linux-gnu/libc.so.6
0x0000000000402BA5 in ./prog.exe
stacktrace 'empty_trace' is indeed empty.

[bearbeiten] Siehe auch

gibt einen Reverse-Iterator zum Anfang zurück
(public member function) [bearbeiten]