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

在 C++23 中,std::stacktrace 提供了获取当前调用栈信息的能力,让开发者可以在运行时打印或分析函数调用路径。这个功能对于调试、日志记录和错误追踪非常有用。
包含头文件并启用支持
C++23 的 std::stacktrace 定义在 头文件中。使用前需要确保编译器支持 C++23 并启用相关选项。
注意:目前(截至 GCC 13、Clang 17)对 std::stacktrace 的支持仍处于实验阶段,通常需要手动开启或链接特定库。
示例编译命令(Clang):
clang++ -std=c++23 -fno-omit-frame-pointer -lunwind main.cpp
基本用法:获取和打印调用栈
通过 std::stacktrace::current() 可以获取当前的调用栈,然后像容器一样遍历它。
立即学习“C++免费学习笔记(深入)”;
简单示例:
#include #includevoid inner_function() {auto trace = std::stacktrace::current();std::cout << "Call stack:n" << trace << 'n';}
void middle_function() {inner_function();}
void outer_function() {middle_function();}
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++标准库获取当前函数调用栈信息的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1485564.html
微信扫一扫
支付宝扫一扫