>我正在尝试建立一种机制,该机制将等待子进程指定的时间并相应地执行其他操作。
我尝试了以下方法:
#include <signal.h>
#include <unistd.h>
#include <stdlib.h>
#include <sys/wait.h>
#include <iostream>
volatile sig_atomic_t p_flag = false;
pid_t makeproc ()
{
pid_t pid;
pid = fork();
// parent
if (pid) return pid;
//child
std::cout << "Child createdn";
sleep(5);
exit(0);
}
void sig_handle (int sig)
{
std::cout << "Handler calledn";
p_flag = true;
}
int main() {
int status;
pid_t child;
int ret;
signal (SIGALRM, sig_handle);
alarm(2);
child = makeproc();
pid_t p = waitpid(-1, &status, 0);
std::cout << "PID: " << p << " FLAG: " << p_flag;
return 0;
}
我从中得到的是,waitpid()
不会被SIGALRM
打断,父级继续等待,直到该过程完成。输出显示生成了SIGALRM
并调用了处理程序。
Child created
Handler called
PID: 31683 FLAG: 1
我无法在处理程序中执行kill()
来杀死孩子。当SIGALRM
被提起时,我怎样才能让wait()
回来?
最有可能的是,在您的操作系统版本中,signal
调用安装处理程序设置了SA_RESTART
标志。设置此标志后,系统调用将在信号处理程序后自动重新启动。
要控制这一点,请不要使用过时和不推荐使用的signal
,请使用sigaction
,并确保不要指定SA_RESTART标志。这应该可以解决您的问题。