1

我正在尝试重现 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.)我在 Devuan 3.0 GNU/Linux 上使用我构建的 Boost 1.73.0。libbacktrace 已安装(它是 glibc 的一部分),我正在链接它。

这更有可能是我做错了什么,还是图书馆中的实际错误?

4

1 回答 1

2

要在堆栈跟踪中获取更多信息,请使用调试构建。对于 GCC,使用标志-g-fno-omit-frame-pointer.

于 2020-07-18T20:12:58.133 回答