linux下定时器setitimer的使用

时间:2021-11-13 23:35:13

1,下面为setitimer函数参数:
int setitimer(int which, const struct itimerval *value, struct itimerval *ovalue));

第一个参数int switch为设置定时器类型:
ITIMER_REAL : 以系统真实的时间来计算,它送出SIGALRM信号。  
 ITIMER_VIRTUAL : -以该进程在用户态下花费的时间来计算,它送出SIGVTALRM 信号。  
 ITIMER_PROF : 以该进程在用户态下和内核态下所费的时间来计算,它送出SIGPROF信号。

第二个参数为设置定时器响应时间,两个结构体。
1,  struct itimerval {
  struct timeval it_interval;
  struct timeval it_value;
  };
  
2、   struct timeval {
  long tv_sec;
  long tv_usec;
  };

struct timeval it_value; 设置定时器初始响应时间,若只定义这个,则定时器只跑一次停止。
struct timeval it_interval;设置定时器每隔多久就响应得时间。
若想关闭定时器,则将两个结构体数据都清零即可。

第三个参数可设置为空NULL。

2,一个简单使用demo,用于定时器只进行一次响应。

#include <stdio.h>
#include <unistd.h>
#include <signal.h>
#include <string.h>
#include <sys/time.h>

static int count = 0;

#define SEC 1
#define USEC 0

void timeout(int signal)
{
printf("Get a SIGALRM, counts = %d!\n",count);
}

int on_timer()
{
struct itimerval tick;
memset(&tick, 0, sizeof(tick));
tick.it_value.tv_sec = SEC;
tick.it_value.tv_usec = USEC;
tick.it_interval.tv_sec = 0;
tick.it_interval.tv_usec = 0;
if(setitimer(ITIMER_REAL, &tick, NULL) < 0)
printf("Set timer failed!\n");
return 0;
}

int off_timer()
{
struct itimerval tick;
memset(&tick, 0, sizeof(tick));
tick.it_value.tv_sec = 0;
tick.it_value.tv_usec = 0;
tick.it_interval.tv_sec = 0;
tick.it_interval.tv_usec = 0;
if(setitimer(ITIMER_REAL, &tick, NULL) < 0)
printf("Set timer failed!\n");
return 0;
}

void *func(void *arg)
{
while(1)
{
printf("hello...\n");
count ++;
if(count%2 == 0)
{
on_timer();
sleep(2);
}
else
off_timer();
}
}

int main()
{
int res = 0;

signal(SIGALRM, timeout);


on_timer();
pthread_t fd;
pthread_create(&fd,NULL,func,NULL);

while(1)
{
sleep(20);
}
return 0;
}