Linux setitimer函數的操作技巧

Linux系統使用setitimer函數能夠事項高精度的定時功能,用于定時執行function,下面小編將針對setitimer函數的用法給大家做個詳細介紹,一起來了解下吧 。

Linux setitimer函數的操作技巧


說明: setitimer一個進程中只能有一個 下一個會覆蓋前一個的定時 想一個進程多個定時器只能自己實現 。
setitimer() 不支持在同一進程中同時使用多次以支持多個定時器 。
linux有關定時器(setitimer)的敘述是這樣的:
linux系統給每個進程提供了3個定時器,每個定時器在各自不同的域里面計數 。當任何一個timer計數到結束了,系統就發送一個信號(signal)給該進程,同時計數器重置 。
一共支持以下3中計數器形式:
ITIMER_REAL 在real time中計數器減1,然后等計數往比后發送SIGALRM信號 。
ITIMER_VIRTUAL 當進程在執行的過程中計數,然后當計數完畢后發送SIGVTALRM信號給該進程 。
ITIMER_PROF 在該進程被執行和系統在代表該進程執行的時間都進行計數
【getitimer/setitimer系統調用】
功能描述:
獲取或設定間歇計時器的值 。系統為進程提供三種類型的計時器,每一類以不同的時間域遞減其值 。當計時器超時,信號被發送到進程,之后計時器重啟動 。
用法:
#include 《sys/time.h》
int getitimer(int which,struct itimerval *value);
int setitimer(int which,const struct itimerval *value,struct itimerval *ovalue);
參數:
which:間歇計時器類型,有三種選擇
ITIMER_REAL //數值為0,計時器的值實時遞減,發送的信號是SIGALRM 。
ITIMER_VIRTUAL //數值為1,進程執行時遞減計時器的值,發送的信號是SIGVTALRM 。
ITIMER_PROF //數值為2,進程和系統執行時都遞減計時器的值,發送的信號是SIGPROF 。
value,ovalue:時間參數,原型如下
struct itimerval
{
struct timeval it_interval;
struct timeval it_value;
};
struct timeval
【Linux setitimer函數的操作技巧】 {
long tv_sec;
long tv_usec;
};
getitimer()用計時器的當前值填寫value指向的結構體 。
setitimer()將value指向的結構體設為計時器的當前值,如果ovalue不是NULL,將返回計時器原有值 。
返回說明:
成功執行時,返回0 。失敗返回-1,errno被設為以下的某個值
EFAULT:value或ovalue是不有效的指針
EINVAL:其值不是ITIMER_REAL,ITIMER_VIRTUAL 或 ITIMER_PROF之一
#include 《stdio.h》
#include 《unistd.h》
#include 《signal.h》
#include 《string.h》
#include 《sys/time.h》
#include 《errno.h》
void PrintMsg(int Num)
{
printf(“%s/n”,“Hello World”);
return;
}
int main(int argc,char* argv[])
{
signal(SIGALRM,PrintMsg);
struct itimerval tick;
tick.it_value.tv_sec = 10; //十秒鐘后將啟動定時器
tick.it_value.tv_usec = 0;
tick.it_interval.tv_sec =1; //定時器啟動后,每隔1秒將執行相應的函數
tick.it_interval.tv_usec = 0;
//setitimer將觸發SIGALRM信號
int ret = setitimer(ITIMER_REAL,&tick,NULL);
if ( ret != 0)
{
printf(“Set timer error. %s /n”,strerror(errno) );
return -1;
}
printf(“Wait!/n”);
getchar();
return 0;
}
上面就是Linux中setitimer函數的用法介紹了,setitimer函數擁有三種類型計時器選擇,為了達到更高精度的定時,還是選擇setitimer函數比較好 。

    推薦閱讀