c – backtrace_symbols无法打印导致信号的函数
发布时间:2020-12-16 09:50:02 所属栏目:百科 来源:网络整理
导读:我正在为我的C应用程序实现一个简单的崩溃记录器: static void handler(int,siginfo_t * info,void *) { void *array[1000]; switch (info-si_signo) { case SIGILL: Logger() "Received SIGILL"; break; case SIGSEGV: Logger() "Received SIGSEGV"; break
我正在为我的C应用程序实现一个简单的崩溃记录器:
static void handler(int,siginfo_t * info,void *) { void *array[1000]; switch (info->si_signo) { case SIGILL: Logger() << "Received SIGILL"; break; case SIGSEGV: Logger() << "Received SIGSEGV"; break; case SIGBUS: Logger() << "Received SIGBUS"; break; case SIGSYS: Logger() << "Received SIGSYS"; break; default: break; } // get void*'s for all entries on the stack const size_t size = backtrace(array,1000); // print out all the frames char ** symbols = backtrace_symbols(array,size); for(size_t i = 0; i < size; ++i) { Logger() << symbols[i]; } free(symbols); exit(EXIT_FAILURE); } struct sigaction SignalAction; SignalAction.sa_flags = SA_SIGINFO; SignalAction.sa_sigaction = handler; sigemptyset(&SignalAction.sa_mask); sigaction(SIGSEGV,&SignalAction,NULL); sigaction(SIGBUS,NULL); sigaction(SIGILL,NULL); 我还没有在Linux上测试它,但是在OS X上,我感兴趣的特定跟踪项目,thatr引起信号的那个,没有被打印(条目号2): : " Received SIGSEGV" : " 0 App 0x0000000100253d15 _ZL7handleriP9__siginfoPv + 229" : " 1 libsystem_platform.dylib 0x00007fff8ff0f5aa _sigtramp + 26" : " 2 ??? 0x000000000000000c 0x0 + 12" : " 3 App 0x000000010000dfa7 _ZN11CMainWindow13initShortcutsEv + 231" : " 4 App 0x000000010000d059 _ZN11CMainWindowC2EP7QWidget + 1001" : " 5 App 0x00000001000091d9 main + 6217" : " 6 App 0x00000001000070a5 _start + 227" : " 7 App 0x0000000100006fc1 start + 33" 为什么会发生这种情况,我可以解决这个问题吗? P. S.这是一个调试版本.没有实际的段错误,它是用raise(SIGSEGV)模拟的. raise是从一个方法调用的,而这个方法又是从MainWindow :: initShortcuts调用的. 解决方法
2号入口有非常特殊的地址.它是0x000000000000000c,你必须知道有中断描述表.根据
http://en.wikipedia.org/wiki/Interrupt_Descriptor_Table,它可能是Stack Fault.
然而正如Ken指出的那样,做你正在做的事情是不好的.这就像试图记住当你的主动脉被撕裂时撞到你的汽车牌照.你能做到但是为了什么? 也许不要尝试学习如何使用strace http://en.wikipedia.org/wiki/Strace. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |