【发布时间】:2014-05-19 01:53:33
【问题描述】:
我想使用以下 C++ 代码等待预定义的时间量(在此示例中始终为 2 秒),但仍可被信号中断(这就是我不使用睡眠的原因):
#include <unistd.h>
#include <stdlib.h>
#include <sys/wait.h>
#include <sys/types.h>
#include <sys/time.h>
#include <signal.h>
#include <iostream>
using namespace std;
int measure() {
itimerval idle;
sigset_t sigset;
int sig;
idle.it_value.tv_sec = 2;
idle.it_value.tv_usec = 0;
setitimer(ITIMER_REAL, &idle, NULL); // TODO: check return value
sigemptyset(&sigset);
sigaddset(&sigset, SIGALRM); // TODO return values
sigaddset(&sigset, SIGUSR1);
sigprocmask(SIG_BLOCK, &sigset, NULL); // TODO return value?
sigwait(&sigset, &sig); // TODO check return value
while(sig != SIGUSR1) {
cout << "Hohoho" << endl;
idle.it_value.tv_sec = 2;
idle.it_value.tv_usec = 0;
setitimer(ITIMER_REAL, &idle, NULL); // TODO: check return value
sigwait(&sigset, &sig); // TODO check return value
}
cout << "Done with measurements." << endl;
return 0;
}
int main(int argc, char **argv) {
//if(fork() != 0) exit(0);
//if(fork() == 0) exit(0);
return measure();
}
我希望这段代码每 2 秒打印一次“Hohoho”,直到它收到 SIGUSR1。然后它打印“完成测量”。并退出。第二部分按预期工作。但是,我没有看到“Hohoho”,所以在我看来,来自 setitimer 的 SIGALRM 以某种方式没有收到。奇怪的是,如果我之前做一个 fork,程序会按预期工作。更具体地说,如果我在最后取消注释两个 fork 命令中的任何一个,它就可以工作。因此,它不取决于它是父进程还是子进程,但不知何故,fork 事件很重要。有人可以向我解释发生了什么以及如何修复我的代码吗?
非常感谢, 卢茨
【问题讨论】:
标签: c++ linux signals fork posix