我在将堆栈跟踪输出到 stderr 或转储到日志文件时遇到问题。我正在使用 gcc 编译器(4.4.3)在 Kubuntu10.04 中运行代码。问题是在正常运行模式下(没有gdb),程序除了'Segmentation Fault' 不输出任何东西。我希望在下面的打印语句中输出回溯输出。当我使用我的应用程序运行 gdb 时,它会出现 printf/fprintf/(function call) 语句,然后由于以下语句而崩溃:
669 {
(gdb)
670 printf("Testing for stability.\n");
(gdb)
Program received signal SIGTRAP, Trace/breakpoint trap.
0x00007ffff68b1f45 in puts () from /lib/libc.so.6
奇怪的是,如果我在同一个文件中调用一个崩溃的函数,它就可以正常工作,并且可以正常输出。但是如果程序在这个文件之外的函数中崩溃,它不会打印任何输出。因此,不会处理任何 printf 或文件转储语句或函数调用。我正在使用以下示例代码:
void bt_sighandler(int sig, siginfo_t *info,
void *secret) {
void *trace[16];
char **messages = (char **)NULL;
int i, trace_size = 0;
ucontext_t *uc = (ucontext_t *)secret;
/* Do something useful with siginfo_t */
if (sig == SIGSEGV)
printf("Got signal %d, faulty address is %p, "
"from %p\n", sig, info->si_addr,
uc->uc_mcontext.gregs[0]);
else
printf("Got signal %d#92; \n", sig);
trace_size = backtrace(trace, 16);
/* overwrite sigaction with caller's address */
trace[1] = (void *) uc->uc_mcontext.gregs[0];
messages = backtrace_symbols(trace, trace_size);
/* skip first stack frame (points here) */
printf("[bt] Execution path:#92; \n");
for (i=1; i<trace_size; ++i)
printf("[bt] %s#92; \n", messages[i]);
exit(0);
}
int main() {
/* Install our signal handler */
struct sigaction sa;
sa.sa_sigaction = (void *)bt_sighandler;
sigemptyset (&sa.sa_mask);
sa.sa_flags = SA_RESTART | SA_SIGINFO;
sigaction(SIGSEGV, &sa, NULL);
sigaction(SIGUSR1, &sa, NULL);
/* Do something */
printf("%d#92; \n", func_b());
}
提前感谢您的帮助。