Backtraceを使用してセグメントエラースタック情報を取得

1749 ワード

詳細については、次の文書を参照してください.https://blog.csdn.net/gatieme/article/details/84189280
テストDemo:
#include 
#include 
#include 
#include 
#include 

void print_trace(void)
{
    void* array[30];
    size_t size;
    char** strings;
    size_t i;


    size = backtrace(array, 30);
    strings = backtrace_symbols(array, size);
    if (NULL == strings)
    {
        perror("backtrace_symbols");
        exit(EXIT_FAILURE);
    }

    printf("Obtained %zd stack frames.
", size); for(i = 0 ; i < size; i++) { printf("%s
", strings[i]); } free(strings); strings = NULL; exit(EXIT_SUCCESS); } void sighandler_dump_stack(int sig) { psignal(sig, "handler"); // print_trace(); signal(sig, SIG_DFL); // raise(sig); // } void dumy_function(void) { print_trace(); } void func_c() { *((volatile int*)0x00) = 0x100; } void func_b() { func_c(); } void func_a() { func_b(); } int main(int argc, char* argv[]) { if (signal(SIGSEGV, sighandler_dump_stack) == SIG_ERR) perror("signal failed"); // : ( +failed): errno func_a(); return 0; }

使用上の注意事項:コンパイル時に追加する必要があります
  • -g:デバッグ情報
  • を追加
  • -rdynamic:シンボル名を増やして
  • をサポート

    セグメントエラーが発生した場合、エラーの位置決め方法


    スタックを表示する前に、SIGSEGV信号のカスタム関数をキャプチャする前のアドレスaddrに入り、
    例外関数の場所を表示するには、次の手順に従います.
  • add32line -C -f -e ./exe_name addr出力は、
  • 例外が発生した関数のソース情報の表示
  • objdump -DS ./handler|grep-6"400 c 74"出力は以下の通り:
  • 転載先:https://www.cnblogs.com/cherishui/p/10341048.html