2

我正在尝试捕获SIGVTALRMsent by setitimer,但我不知道为什么它不起作用。这是我的代码:

void time(int time) {
    cout << "time" << endl;
    exit(0);
}

int main(void) {
    signal(SIGVTALRM, time);
    itimerval tv;
    tv.it_value.tv_sec = 5;
    tv.it_value.tv_usec = 0;
    tv.it_interval.tv_sec = 5;
    tv.it_interval.tv_usec = 0;
    setitimer(ITIMER_VIRTUAL, &tv, NULL);
    while (true) {
        cout << "waiting" << endl;
    }
    return 0;
}

出于某种原因,它从不调用time()- 是因为它没有捕获信号还是因为我不知道一开始就没有发送信号。

这应该很简单。有任何想法吗?谢谢

4

2 回答 2

0

你确定它不工作吗?

在我看来一切都很好。可能是你等的还不够。由于您在循环内打印字符串waiting并且您正在使用虚拟计时器,因此时钟仅在进程运行时才会滴答作响(不包括 IO 时间)。因此,实际上您的计时器可能会在几(> 5)秒后到期。

尝试注释掉打印部分。

于 2012-04-26T10:05:16.610 回答
0

这是由于signal功能。如http://manpages.ubuntu.com/manpages//precise/en/man2/signal.2.html中所述:

The  behavior  of  signal()  varies  across UNIX versions, and has also varied historically across different versions of Linux.  Avoid its use: use sigaction(2) instead.

所以主要的方法应该是:

int main(void) {
    itimerval tv;
    struct sigaction sa;

    sigemptyset(&sa.sa_mask);
    sa.sa_flags = 0;
    sa.sa_handler = timer_handler;
    if (sigaction(SIGVTALRM, &sa, NULL) == -1) {
        printf("error with: sigaction\n");
        exit(EXIT_FAILURE);
    }

    tv.it_value.tv_sec = 5;
    tv.it_value.tv_usec = 0;
    tv.it_interval.tv_sec = 5;
    tv.it_interval.tv_usec = 0;
    setitimer(ITIMER_VIRTUAL, &tv, NULL);

    while (true) {
        cout << "waiting" << endl;
    }

    return 0;
}
于 2014-01-16T04:22:51.060 回答