1.介紹
在linux下如果定時如果要求不太精確的話,使用alarm()和signal()就行了(精確到秒),但是如果想要實現精度較高的定時功能的話,就要使用setitimer函數。
setitimer()為Linux的API,並非C語言的Standard Library,setitimer()有兩個功能,一是指定一段時間后,才執行某個function,二是每間格一段時間就執行某個function, 以下程序demo如何使用setitimer()。
2.函數參數
1 int setitimer(int which, const struct itimerval *value, struct itimerval *ovalue)); 2 3 struct itimerval { 4 struct timeval it_interval; 5 struct timeval it_value; 6 }; 7 struct timeval { 8 long tv_sec; 9 long tv_usec; 10 };
其中,which為定時器類型,3中類型定時器如下:
ITIMER_REAL : 以系統真實的時間來計算,它送出SIGALRM信號。
ITIMER_VIRTUAL : -以該進程在用戶態下花費的時間來計算,它送出SIGVTALRM信號。
ITIMER_PROF : 以該進程在用戶態下和內核態下所費的時間來計算,它送出SIGPROF信號。
第二個參數指定間隔時間,第三個參數用來返回上一次定時器的間隔時間,如果不關心該值可設為NULL。
it_interval指定間隔時間,it_value指定初始定時時間。如果只指定it_value,就是實現一次定時;如果同時指定 it_interval,則超時后,系統會重新初始化it_value為it_interval,實現重復定時;兩者都清零,則會清除定時器。
tv_sec提供秒級精度,tv_usec提供微秒級精度,以值大的為先,注意1s = 1000000us。
如果是以setitimer提供的定時器來休眠,只需阻塞等待定時器信號就可以了。
setitimer()調用成功返回0,否則返回-1。
3.范例
該示例程序每隔1s產生一行標准輸出。
#include <stdio.h> //printf() #include <unistd.h> //pause() #include <signal.h> //signal() #include <string.h> //memset() #include <sys/time.h> //struct itimerval, setitimer() static int count = 0; void printMes(int signo) { printf("Get a SIGALRM, %d counts!\n", ++count); } int main() { int res = 0; struct itimerval tick; signal(SIGALRM, printMes); memset(&tick, 0, sizeof(tick)); //Timeout to run first time tick.it_value.tv_sec = 1; tick.it_value.tv_usec = 0; //After first, the Interval time for clock tick.it_interval.tv_sec = 1; tick.it_interval.tv_usec = 0; if(setitimer(ITIMER_REAL, &tick, NULL) < 0) printf("Set timer failed!\n"); //When get a SIGALRM, the main process will enter another loop for pause() while(1) { pause(); } return 0; }
參考:http://hi.baidu.com/luxiong200245/blog/item/b8e5fff3ab3cea4e342accdb.html
