Backtrace in std::backtrace - Rust (original) (raw)
Struct Backtrace
1.65.0 · Source
pub struct Backtrace { /* private fields */ }
Expand description
A captured OS thread stack backtrace.
This type represents a stack backtrace for an OS thread captured at a previous point in time. In some instances the Backtrace
type may internally be empty due to configuration. For more information seeBacktrace::capture
.
1.65.0 · Source
Captures a stack backtrace of the current thread.
This function will capture a stack backtrace of the current OS thread of execution, returning a Backtrace
type which can be later used to print the entire stack trace or render it to a string.
This function will be a noop if the RUST_BACKTRACE
orRUST_LIB_BACKTRACE
backtrace variables are both not set. If either environment variable is set and enabled then this function will actually capture a backtrace. Capturing a backtrace can be both memory intensive and slow, so these environment variables allow liberally usingBacktrace::capture
and only incurring a slowdown when the environment variables are set.
To forcibly capture a backtrace regardless of environment variables, use the Backtrace::force_capture
function.
1.65.0 · Source
Forcibly captures a full backtrace, regardless of environment variable configuration.
This function behaves the same as capture
except that it ignores the values of the RUST_BACKTRACE
and RUST_LIB_BACKTRACE
environment variables, always capturing a backtrace.
Note that capturing a backtrace can be an expensive operation on some platforms, so this should be used with caution in performance-sensitive parts of code.
1.65.0 (const: 1.65.0) · Source
Forcibly captures a disabled backtrace, regardless of environment variable configuration.
1.65.0 · Source
Returns the status of this backtrace, indicating whether this backtrace request was unsupported, disabled, or a stack trace was actually captured.
🔬This is a nightly-only experimental API. (backtrace_frames
#79676)
Returns an iterator over the backtrace frames.