C++23中std::stacktrace可获取调用栈,需包含<stacktrace>并启用C++23支持;目前GCC 13、Clang 17仍为实验性,需手动开启或链接-lunwind;通过std::stacktrace::current()获取栈帧,可遍历打印函数名、文件行号等信息,适用于调试、异常追踪;示例输出包含各级调用函数及位置,支持自定义格式化和部分帧提取;实际可用于异常处理、断言失败等场景,但需注意平台兼容性和发布前测试。

在 C++23 中,std::stacktrace 提供了获取当前调用栈信息的能力,让开发者可以在运行时打印或分析函数调用路径。这个功能对于调试、日志记录和错误追踪非常有用。
C++23 的 std::stacktrace 定义在 <stacktrace> 头文件中。使用前需要确保编译器支持 C++23 并启用相关选项。
std::stacktrace 的支持仍处于实验阶段,通常需要手动开启或链接特定库。示例编译命令(Clang):
clang++ -std=c++23 -fno-omit-frame-pointer -lunwind main.cpp
通过 std::stacktrace::current() 可以获取当前的调用栈,然后像容器一样遍历它。
立即学习“C++免费学习笔记(深入)”;
简单示例:
#include <iostream>
#include <stacktrace>
<p>void inner_function() {
auto trace = std::stacktrace::current();
std::cout << "Call stack:\n" << trace << '\n';
}</p><p>void middle_function() {
inner_function();
}</p><p>void outer_function() {
middle_function();
}</p><p>int main() {
outer_function();
return 0;
}
输出可能类似:
Call stack: 0# inner_function() at main.cpp:5 1# middle_function() at main.cpp:10 2# outer_function() at main.cpp:14 3# main at main.cpp:18
你可以控制输出多少帧,或者提取特定信息,比如函数名。
示例:只打印前两级调用
auto trace = std::stacktrace::current();
for (std::size_t i = 0; i < trace.size() && i < 2; ++i) {
std::cout << "Frame " << i << ": "
<< trace[i].description() << '\n';
}
trace[i].description() 返回函数名(可能包含修饰),trace[i].source_file() 和 trace[i].source_line() 可用于获取源码位置(若可用)。
在异常处理中加入栈追踪能极大提升调试效率:
void log_error() {
try {
throw;
} catch (const std::exception& e) {
std::cerr << "Exception: " << e.what() << "\n";
}
std::cerr << "Stack trace:\n" << std::stacktrace::current() << '\n';
}
可在关键函数入口、断言失败或资源泄漏检测时调用。
基本上就这些。虽然 std::stacktrace 使用简单,但依赖平台和编译器支持,发布前需充分测试。
以上就是C++23的std::stacktrace怎么用_C++标准库获取当前函数调用栈信息的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号