定时器

定时器并不是一种并发[线程],而是一种延迟,是一种异步,由当前线程执行,即如果定时器任务中有阻塞,会阻塞主线程。

alarm

gettimer/settimer

共同点:使用信号;

不同点:settimer可以自动重启和有三个独有模式,并且时间精度不仅仅只有秒。

#include <sys/time.h>

int settimer (int which,
              const struct itimerval *value,
              struct itimerval *ovalue);

// which ITIMER_REAL 测量真实时间,如果调试模式中,断点停止前时间不同,不同时间触发
//       ITIMER_VIRTUAL 进程用户空间代码执行减少,指定的进程时间过去后
//       ITIMER_PROF 与ITIMER_VIRTUAL共用,衡量进程消耗的用户时间和内核时间

// value itimerval
struct itimerval {
        struct timeval it_interval; // 下一次delay时间
        struct timeval it_value;    // settimer设置一个过期时间为it_value的定时器
                                    // 一旦时间超过it_value,内核使用it_interval的时长重启定时器
};

高级定时器[Linux系统编程 P372,这本书推荐反复读,但是其中不好的地方在于某些章节写了部详细,结构编排有点乱,例如高级定时器],更加多形式,同时更加复杂

创建定时器

#include <signal.h>
#include <time.h>

int timer_create(clockid_t clockid,
                 struct sigevent *evp,
                 timer_t *timerid); // 调用成功会将定时器标记保存在 timerid中

// clockid_t CLOCK_REALTIME
//           CLOCK_PROCESS_CPUTIME_ID
//           

struct sigevent {
        union sigval sigev_value;
        int sigev_signo;
        int sigev_notify;
        void (*sigev_notify_function)(union sigval);
        pthread_attr_t *sigev_notify_attributes;
};

union sigval {
        int sival_int;
        void *sival_ptr;
};


// sigev_notify SIGEV_NONE 定时器到期时,什么也不发生
//              SIGEV_SIGNAL 定时器到期时,内核给进程发送一个sigev_signo指定的信号
//              SIGEV_THREAD 定时器到期时,会产生一个新线程,执行 sigev_notify_function将
//                           sigev_value作为它唯一的参数,这个线程函数返回时终止

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章