Backtraceを使用してセグメントエラースタック情報を取得
1749 ワード
詳細については、次の文書を参照してください.https://blog.csdn.net/gatieme/article/details/84189280
テストDemo:
使用上の注意事項:コンパイル時に追加する必要があります-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
テスト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;
}
使用上の注意事項:コンパイル時に追加する必要があります
セグメントエラーが発生した場合、エラーの位置決め方法
スタックを表示する前に、SIGSEGV信号のカスタム関数をキャプチャする前のアドレスaddrに入り、
例外関数の場所を表示するには、次の手順に従います.