使用 alarm() 实现进程超时



>我正在尝试建立一种机制,该机制将等待子进程指定的时间并相应地执行其他操作。

我尝试了以下方法:

#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标志。这应该可以解决您的问题。

相关内容

  • 没有找到相关文章

最新更新