标签:style blog color strong 2014 os
先看一段代码
#include <stdio.h>
#include <time.h>
#include <sys/time.h>
#include <stdlib.h>
#include <signal.h>
static int count = 0;
void set_timer()
{
	struct itimerval itv;
	itv.it_value.tv_sec = 3;    //timer start after 3 seconds later
	itv.it_value.tv_usec = 0;
	itv.it_interval.tv_sec = 1;
	itv.it_interval.tv_usec = 0;
	setitimer(ITIMER_REAL,&itv,NULL);
}
void signal_handler(int m)
{
	count ++;
	printf("%d\n",count);
}
int main()
{
	signal(SIGALRM,signal_handler);
	set_timer();
	while(count < 10);
	exit(0);
	return 0;
}
结构体原型:
struct itimerval {
                struct timeval it_interval; /* next value */
                struct timeval it_value;    /* current value */
            };struct timeval {
                long tv_sec;                /* seconds */
                long tv_usec;               /* microseconds */
            };即:
struct itimerval {
    struct timeval it_interval; /* 计时器重启动的间歇值 */
    struct timeval it_value;    /* 计时器安装后首先启动的初始值 */
};
struct timeval {
    long tv_sec;                /* 秒 */
    long tv_usec;               /* 微妙(1/1000000) */
};int setitimer(int which, const struct itimerval *value,struct itimerval *ovalue);
setitimer()将value指向的结构体设为计时器的当前值,如果ovalue不是NULL,将返回计时器原有值。
which:间歇计时器类型,有三种选择
ITIMER_REAL      //数值为0,计时器的值实时递减,发送的信号是SIGALRM。
ITIMER_VIRTUAL //数值为1,进程执行时递减计时器的值,发送的信号是SIGVTALRM。
ITIMER_PROF     //数值为2,进程和系统执行时都递减计时器的值,发送的信号是SIGPROF。
返回说明: 
成功执行时,返回0。失败返回-1,errno被设为以下的某个值 
EFAULT:value或ovalue是不有效的指针
EINVAL:其值不是ITIMER_REAL,ITIMER_VIRTUAL 或 ITIMER_PROF之一
Linux struct itimerval用法,布布扣,bubuko.com
标签:style blog color strong 2014 os
原文地址:http://blog.csdn.net/hbuxiaofei/article/details/35569229