在C中用定时器计算时间

Counting time with timer in C

我想 运行 在特定时间内执行 C 程序。这段时间之后程序应该终止。我搜索了一些关于它的文档,但其中很多都使用 sleep 函数。我不想用它。我想在无限循环中检查当前时间是否大于目标时间。

例如下面的代码,我的目标时间是 5,当 运行ning 持续时间大于 5 时,程序应该终止。

但是代码导致了无限循环。我该如何解决这个问题?

void thread_handler(union sigval sv) {
    char *s = sv.sival_ptr;
    /* Will print "5 seconds elapsed." */
    puts(s);
}

int main(void) {
    char info[] = "5 seconds elapsed.";
    timer_t timerid;
    struct sigevent sev;
    struct itimerspec trigger;
    struct itimerspec triggerAfter;

    memset(&sev, 0, sizeof(struct sigevent));
    memset(&trigger, 0, sizeof(struct itimerspec));

    sev.sigev_notify = SIGEV_THREAD;
    sev.sigev_notify_function = &thread_handler;
    sev.sigev_value.sival_ptr = &info;

    timer_create(CLOCK_REALTIME, &sev, &timerid);

    trigger.it_value.tv_sec = 5;

    timer_settime(timerid, 0, &trigger, NULL); 

    timer_gettime(timerid,&trigger);
    while (1) {
        if ((int)trigger.it_value.tv_sec > 5) { //checking the current time is bigger than the target time, it it is then exit from the program
            timer_delete(timerid);
            exit(0);
        }
    }
}

如果你想在一个繁忙的循环中检查和比较,你可以简单地调用clock_gettime并且完全避免定时器。 计时器的全部意义在于避免这种繁忙的循环。

在你的情况下,你的主线程可以简单地暂停,你可以退出 thread_handler 函数,即 运行 在计时器处理程序的专用线程上。

#include <time.h>
#include <signal.h>
#include <string.h>
#include <stdlib.h>
#include <stdio.h>
#include <unistd.h>
void thread_handler(union sigval sv) {
    char *s = sv.sival_ptr;
    /* Will print "5 seconds elapsed." */
    puts(s);
    exit(0);
}

int main(void) {
    char info[] = "5 seconds elapsed.";
    timer_t timerid;
    struct sigevent sev;
    struct itimerspec trigger;
    struct itimerspec triggerAfter;

    memset(&sev, 0, sizeof(struct sigevent));
    memset(&trigger, 0, sizeof(struct itimerspec));

    sev.sigev_notify = SIGEV_THREAD;
    sev.sigev_notify_function = &thread_handler;
    sev.sigev_value.sival_ptr = &info;

    if(0>timer_create(CLOCK_REALTIME, &sev, &timerid)) return perror("timer_create"),1;

    trigger.it_value.tv_sec = 5;

    if(0>timer_settime(timerid, 0, &trigger, NULL)) return perror("timer_settime"),1;

    pause();

}

如果你还想忙检查,你需要在等待循环中有timer_gettime。只调用一次不会使 trigger 对象自动更新。