0

我必须管理以下信号:SIGHUP, SIGINT, SIGQUIT,SIGTERM 下面的代码是一个示例SIGHUP

int sock_ds, acc_sock_ds; //TCP sockets

void shutdown(int sig){
    close(sock_ds);
    close(acc_sock_ds);
    raise(sig);
}

/*Sets the disposition of a signal
 * Returns 0 on success, -1 on error */
int sig_disp(int sig, void (* handler)(int), int flag){
    struct sigaction sa;
    memset((char *)&sa, 0, sizeof(sa));
    sa.sa_handler = handler;
    sa.sa_flags = flag;
    sigemptyset(&sa.sa_mask);
    return sigaction(sig, &sa, NULL);
}
int main(){

    /*...*/

    /*--- Signal management ---*/
    sigset_t set;
    /*sigset filling with all signal*/
    if(sigfillset(&set) == -1){
        fprintf(stderr, "Signal set fill error\n");
        exit(EXIT_FAILURE);
    }

    /*...*/ 

    if(sigdelset(&set, SIGHUP) == -1){
        fprintf(stderr, "Signal set action error\n");
        exit(EXIT_FAILURE);
    }

    /*...*/

   /*Changing signals disposition*/
   if(sig_disp(SIGHUP, shutdown, SA_RESETHAND));

   /*...*/

   /*Remaining signals are inserted into process signal mask (blocked) */
   if(sigprocmask(SIG_BLOCK, &set, NULL) == -1){
       fprintf(stderr, "Process signal mask action error\n");
       exit(EXIT_FAILURE);
   }

   /*...*/
}

我的想法是重新激活信号的默认处理,即终止进程并在清理操作后重新引发相同的信号。

我如何传递sig给关机功能sa.sa_handler = handler;

此外,在这些情况下,通常会采取哪些清洁措施?我的场景是带有 TCP 套接字和一些打开文件的单线程服务器。

4

2 回答 2

1

退出时无需关闭套接字、文件、任何内容或释放内存。无论如何,操作系统都会这样做,你只是在浪费时间做两次事情。

终止只是使用

exit(0);

要将信号处理程序重置为原始处理程序,而不是将 sigaction 的最后一个参数设置为 NULL,您必须传递一个指针,该指针将设置为前一个处理程序的地址。

当您使用信号更改处理程序时,它将返回前一个处理程序的指针

于 2013-03-11T20:35:16.800 回答
0

当您说“管理以下信号”时,您要实现什么目标?

如果只是在收到通常会终止进程的信号后进行一些自定义清理,则可以使用对atexit的调用来注册清理函数。

于 2013-03-11T20:33:45.710 回答