我正在windows下移植Linux/gcc程序,併爲兩者實現了常見的異常處理。我想知道MinGW/gcc的信號相當於SIGINT
。相當於用於在Windows下捕獲「CTRL + C」的「SIGINT」(posix)信號/ MinGW
這是我如何處理它在Linux下:
static void handler(int sig)
{
// Catch exceptions
switch(sig)
{
case SIGABRT:
fputs("Caught SIGABRT: usually caused by an abort() or assert()\n", stderr);
break;
case SIGFPE:
fputs("Caught SIGFPE: arithmetic exception, such as divide by zero\n",
stderr);
break;
case SIGILL:
fputs("Caught SIGILL: illegal instruction\n", stderr);
break;
case SIGINT:
fputs("Caught SIGINT: interactive attention signal, probably a ctrl+c\n",
stderr);
break;
case SIGSEGV:
fputs("Caught SIGSEGV: segfault\n", stderr);
break;
case SIGTERM:
default:
fputs("Caught SIGTERM: a termination request was sent to the program\n",
stderr);
break;
}
// Ctrl+C interrupt => No backtrace
if (sig != (int)SIGINT)
{
fprintf(stderr, "Error: signal %d:\n", sig);
posix_print_stack_trace();
}
exit(sig);
}
signal(SIGABRT, handler);
signal(SIGFPE, handler);
signal(SIGILL, handler);
signal(SIGINT, handler);
signal(SIGSEGV, handler);
signal(SIGTERM, handler);
在Windows下,這看起來像:
static LONG WINAPI windows_exception_handler(EXCEPTION_POINTERS * ExceptionInfo)
{
switch(ExceptionInfo->ExceptionRecord->ExceptionCode)
{
case EXCEPTION_ACCESS_VIOLATION:
fputs("Error: EXCEPTION_ACCESS_VIOLATION\n", stderr);
break;
case EXCEPTION_ARRAY_BOUNDS_EXCEEDED:
fputs("Error: EXCEPTION_ARRAY_BOUNDS_EXCEEDED\n", stderr);
break;
case EXCEPTION_BREAKPOINT:
fputs("Error: EXCEPTION_BREAKPOINT\n", stderr);
break;
...
}
}
if (EXCEPTION_STACK_OVERFLOW != ExceptionInfo->ExceptionRecord->ExceptionCode)
{
windows_print_stacktrace(ExceptionInfo->ContextRecord);
}
我的問題是,我沒有看到任何SIGINT
相當於在EXCEPTION_*
適用於Windows。如何在Windows(MinGW/gcc)下捕獲「CTRL + C」中斷?
非常感謝。
無論如何它仍然是SIGINT。 SIGBREAK用於Ctrl + Break按鍵。不,這不會通過爲SetUnhandledException()安裝的回調。它不是未處理的:) SetConsoleCtrlHandler()以便及早查看它。 –