程序运行中,经常会出现类似段错误、信号量错误等方面的问题,导致程序崩溃。
针对这一类问题,解决的方法有很多,如coredump, gdb等;
这里,我介绍一种简单的方式,可以在程序崩溃的时候捕捉到栈信息,代码如下:
01.void Dump(int signum)
02.{
-
void *array[10];
-
size_t size;
-
char **strings;
-
size_t i;
-
char log[128];
-
signal(signum, SIG_DFL);
-
size = backtrace(array, 10);
-
strings = (char **) backtrace_symbols(array, size);
-
GetFreeMemory();
-
fprintf(stderr, “widebright received SIGNUM = %d! Stack trace:size = %d\n”, signum, size);
-
for (i = 0; i < size; i++)
-
{
-
fprintf(stderr, "%d %s \n", i, strings);
-
}
-
free(strings);
20.}
22.static int InstallSEGVHandler(void)
23.{
-
struct sigaction siga;
-
siga.sa_handler = AkDump;
-
siga.sa_flags = 0;
-
memset(&siga.sa_mask, 0, sizeof(sigset_t));
-
sigaction(SIGSEGV, &siga, NULL);
-
sigaction(SIGILL, &siga, NULL);
-
sigaction(SIGTERM, &siga, NULL);
-
sigaction(SIGILL, &siga, NULL);
-
sigaction(SIGABRT, &siga, NULL);
-
sigaction(SIGFPE, &siga, NULL);
-
return 1;
38.}
复制代码
当程序出现段错误之类的错误时,系统会发出相应的信号量(具体信号量请查找Linux信号量之SIGNAL),
同时可以抓取并打印信号量的值以及相应的栈信息,栈信息类似如下:
0 ./mainapp [0xcc80]
1 /lib/libc.so.6(__default_sa_restorer_v2+0) [0x40451580]
2 /usr/lib/libakaudiocodec.so(raac_DecodeNoiselessData+0x4b4) [0x400c7fc0]
3 /usr/lib/libakaudiocodec.so(AACDecode+0x468) [0x400c16e0]
4 /usr/lib/libakaudiocodec.so(_SD_AAC_Decode+0x2d8) [0x400c2278]
5 /usr/lb/libakaudiocodec.so(_SD_Decode+0x64) [0x400bf560]
6 ./mainapp [0x23734]
7 /lib/libpthread.so.0 [0x405719bc]
8 /lib/libc.so.6(clone+0x88) [0x404fcc58]
捕获到栈信息后,使用objdump工具将应用进行反汇编,如:arm-none-linux-gnueabi-objdump -S mainapp > a
最后便可用栈信息打印出来的地址( ./mainapp [0x23734]–),到a文件中进行定位,找到出现问题的函数接口。