当Linux子进程异常退出时,通常会产生一个信号(signal),通知父进程子进程已经退出
signal()
或sigaction()
函数为SIGCHLD
信号安装一个信号处理器。这个处理器将在子进程异常退出时被调用。#include<signal.h>
#include <sys/wait.h>
void handle_sigchld(int sig) {
// 在这里处理子进程的退出
}
int main() {
signal(SIGCHLD, handle_sigchld);
// 或者使用 sigaction() 函数
// struct sigaction sa;
// sa.sa_handler = handle_sigchld;
// sigemptyset(&sa.sa_mask);
// sa.sa_flags = SA_RESTART;
// sigaction(SIGCHLD, &sa, NULL);
// ... 其他代码
}
waitpid()
或wait()
函数来获取子进程的退出状态。这样你可以检查子进程是否因为异常而退出,并获取相关信息。void handle_sigchld(int sig) {
pid_t pid;
int status;
while ((pid = waitpid(-1, &status, WNOHANG)) > 0) {
if (WIFEXITED(status)) {
printf("子进程 %d 正常退出,退出码: %d\n", pid, WEXITSTATUS(status));
} else if (WIFSIGNALED(status)) {
printf("子进程 %d 因信号 %d 而异常退出\n", pid, WTERMSIG(status));
// 在这里处理子进程的异常退出,例如重启子进程
}
}
}
注意:在信号处理器中,应避免使用不可重入的函数(non-reentrant functions),因为它们可能会导致死锁或其他问题。在上面的示例中,我们使用了printf()
,但在实际应用中,你可能需要使用更安全的方法来记录日志或处理子进程的退出。