溫馨提示×

Linux stacktrace 如何獲取完整堆棧

小樊
81
2024-10-02 05:10:04

在 Linux 系統(tǒng)中,獲取完整的堆棧跟蹤可以幫助你定位程序中的錯(cuò)誤或異常。你可以使用 backtrace()backtrace_symbols() 函數(shù)來獲取堆棧跟蹤,然后使用 addr2line() 函數(shù)將地址轉(zhuǎn)換為對應(yīng)的源代碼行。

以下是一個(gè)簡單的示例,說明如何獲取完整的堆棧跟蹤:

  1. 首先,確保你的程序已經(jīng)編譯并鏈接了調(diào)試信息。使用 -g 選項(xiàng)編譯你的程序,例如:
gcc -g my_program.c -o my_program
  1. 在你的程序中,包含 <execinfo.h> 頭文件,并使用 backtrace()backtrace_symbols() 函數(shù)獲取堆棧跟蹤。例如:
#include <stdio.h>
#include <execinfo.h>
#include <unistd.h>

void print_backtrace() {
    void *array[100];
    size_t size;

    // 獲取堆棧跟蹤
    size = backtrace(array, 100);

    // 打印堆棧跟蹤
    printf("Error: signal %d:\n", errno);
    backtrace_symbols_fd(array, size, STDERR_FILENO);
}

int main() {
    print_backtrace();
    return 0;
}
  1. 運(yùn)行你的程序,當(dāng)發(fā)生錯(cuò)誤時(shí),它將打印出完整的堆棧跟蹤。例如:
./my_program
  1. 若要獲取更詳細(xì)的源代碼行信息,可以使用 addr2line() 函數(shù)。首先,你需要安裝 binutils 軟件包(如果尚未安裝):
sudo apt-get install binutils
  1. 然后,使用 addr2line() 函數(shù)將堆棧跟蹤中的地址轉(zhuǎn)換為對應(yīng)的源代碼行。例如:
addr2line -f -e my_program < /proc/<pid>/stack | tail

其中,<pid> 是你的程序進(jìn)程的 ID。這將顯示堆棧跟蹤中最后幾個(gè)函數(shù)的源代碼行。

通過這些步驟,你應(yīng)該能夠獲取并查看完整的堆棧跟蹤,從而更容易地找到程序中的錯(cuò)誤或異常。

0