내 C에 대한 간단한 충돌 로거를 구현하고있어 ++ 응용 프로그램 발생했습니다 매우 기능 인쇄 실패backtrace_symbols는 신호
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, &SignalAction, NULL);
sigaction(SIGILL, &SignalAction, NULL);
나는 아직 리눅스에 그것을 테스트하지 않은,하지만 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. 이것은 디버그 빌드입니다. 실제 segfault는 없었으며 raise(SIGSEGV)
으로 시뮬레이션되었습니다. raise
은 MainWindow::initShortcuts
에서 호출 된 메서드에서 호출되었습니다.
출력이 어떻게 될 것으로 예상합니까?이 추적이 잘못되었음을 어떻게 알 수 있습니까?스택 손상이 발생했거나 (백 트레이스를 엉망으로 만들었을 때) 프로세스가 0xC 주소로 점프하려고 시도했을 가능성이 있습니다 (메모리 손상, 프로그래밍 오류 등으로 인해). –
글쎄, C++을 사용하고 있기 때문에'std :: exception'에서 파생 될 수 있고 파생 된 예외의 생성자에서'std :: string'의'std :: list'에 스택 추적 정보를 빌드 할 수 있습니다 그 파생 된 클래스를 던지십시오. 대답이 표시되면 정확한 스택 추적을 제공하기 위해 신호 처리기에 의존해서는 안됩니다. – rwols
@AndrewMedico : 업데이트 된 질문 (바닥 글 - P. 섹션 참조)을 참조하십시오. –