无法通过Boost堆栈跟踪+回溯获取行号



我试图重现Boost Stacktrace文档中的第一个也是最简单的例子。

#define BOOST_STACKTRACE_USE_BACKTRACE
#include <boost/stacktrace.hpp>
#include <iostream>
void bar(int n) {
if (n <= 0) {
// ... somewhere inside the `bar(int)` function that is called recursively:
std::cout << boost::stacktrace::stacktrace();
return;
}
bar(n-1);
}
int main() {
bar(4);
}

我只取得了部分成功:我得到了函数名,但没有得到行:

0# bar(int) in ./plain_vanilla
1# bar(int) in ./plain_vanilla
2# bar(int) in ./plain_vanilla
3# bar(int) in ./plain_vanilla
4# bar(int) in ./plain_vanilla
5# main in ./plain_vanilla
6# __libc_start_main at ../csu/libc-start.c:342
7# _start in ./plain_vanilla

(我的源文件名为plain_vanilla.cpp,可执行文件为plain_vanilla。(我使用的是Boost 1.73.0,它是我在Devuan 3.0 GNU/Linux上构建的。libbacktrace已经安装(它是glibc的一部分(,我正在链接它。

这更可能是我做错了什么,还是库中的一个实际错误?

要在堆栈跟踪中获得更多信息,请使用调试构建。对于GCC,编译带有标志-g-fno-omit-frame-pointer的项目。

相关内容

最新更新