#ifdef WIN32
/*
CTRL_C_EVENT - 当用户按下了CTRL+C,或者由GenerateConsoleCtrlEvent API发出.
CTRL_BREAK_EVENT - 用户按下CTRL+BREAK, 或者由GenerateConsoleCtrlEvent API发出.
CTRL_CLOSE_EVENT - 当试图关闭控制台程序,系统发送关闭消息。
CTRL_LOGOFF_EVENT - 用户退出时,但是不能决定是哪个用户.
CTRL_SHUTDOWN_EVENT - 当系统被关闭时.*/
BOOL WINAPI handle(DWORD event)
{
switch(event)
{
case CTRL_CLOSE_EVENT:
case CTRL_C_EVENT:
{
is_done = 1;
}
return TRUE;
}
return FALSE;
}
#else
/*
SIGINT
程序终止(interrupt)信号, 在用户键入INTR字符(通常是Ctrl-C)时发出,用于通知前台进程组终止进程
SIGQUIT
和SIGINT类似, 但由QUIT字符(通常是Ctrl-\)来控制. 进程在因收到SIGQUIT退出时会产生core文件, 在这个意义上类似于一个程序错误信号
SIGTERM
程序结束(terminate)信号, 与SIGKILL不同的是该信号可以被阻塞和处理。通常用来要求程序自己正常退出,shell命令kill缺省产生这个信号。如果进程终止不了,我们才会尝试SIGKILL
SIGSTOP
停止(stopped)进程的执行. 注意它和terminate以及interrupt的区别:该进程还未结束, 只是暂停执行. 本信号不能被阻塞, 处理或忽略
*/
void handle(int event)
{
switch (event)
{
case SIGINT:
case
}
}
#endif
int main(int argc, char *argv[])
{
#ifdef WIN32
if( !SetConsoleCtrlHandler( Handler, TRUE ) )
{
fprintf( stderr, "error setting event handler.\n" );
return -1;
}
#else
signal(SIGINT, sig_handle); // register "Ctrl + c" event handling callback, and if considering the security of call, it is replaced by sigaction.
#endif
}