Ark*_*ady 5 c++ linux fork exec
我有父进程,必须创建几个子进程.我发现最好的方法是使用fork+ execl.但是父进程需要知道execl具体的孩子是否失败,我不知道如何实现.
int pid = fork();
if (pid < 0) {
std::cout << "ERROR on fork." << std::endl;
} if (pid == 0) {
execl("/my/program/full/path", (char *)NULL);
exit(1);
}
else {
if (/*child's process execl fails*/) {
std::cout << "it failed" << std::endl
} else {
std::cout << "child born" << std::endl
}
}
Run Code Online (Sandbox Code Playgroud)
我认为这个想法并不好:
int status(0);
sleep(100);
int res = waitpid(pid, &status, WNOHANG);
if (res < 0 && errno == 10) {
std::cout << "it failed" << std::endl
} else {
std::cout << "child born" << std::endl
}
Run Code Online (Sandbox Code Playgroud)
因为希望儿童过程在100毫秒后死亡并不好,我想知道,因为只有那样才会发生.
我还认为为这种检查创建shared_memory或特殊管道连接是针对Bees的Cannon.
必须有简单的解决方案,我还没有找到.
实现这一目标的最佳方法是什么?
作为通用解决方案,您可以使用 sigaction() 在父级中注册信号处理程序 (SIGUSR1)。
在子进程中:取消注册信号处理程序,如果 execl() 调用失败,则需要将 SIGUSR1 发送给父进程。
在父进程中:我们将把每个子进程的 pid 存储在 std::set 中。创建所有子项后,您只需创建一个单独的线程来跟踪子项。在线程函数中,只需调用 wait() 并从集合中删除 pid。另一种监听 SIGCHLD 信号的方法(但它会导致更复杂的解决方案,因此如果生成另一个线程是我会使用线程的选项)。
当集合为空时我们就完成了。