最近內(nèi)部有個考試,提到 異步IO實(shí)現(xiàn)更精確定時器的題目,讓我比較迷惑。由此開始尋找資料,想分析一下。
誰知幾年不研究了,發(fā)現(xiàn)好多函數(shù)類似的,讓人頭暈。先就把一些函數(shù)列出來,等以后慢慢學(xué)習(xí)之吧。
sleep, usleep, nanosleep(AIX unix man里沒有,可是可以使用): 同步等待
alarm, ualarm: 異步信號通知
settimer, setitimer: 異步信號通知,
select : 精確到10ms(毫秒)級的 定時。
aio 異步通知: 還不確定怎么使用。
----------------------------------------------------------------------------------
- setitimer 比較 alarm
不同: setitimer 可以設(shè)置第一次的調(diào)用間隔時間,可能有些好處,如希望第一次信號 發(fā)生時已經(jīng)完成了一些系統(tǒng)初始化的工作 ,而這些工作最好不要有信號發(fā)生。
相同: # 觸發(fā)方式: 都是 發(fā)送 SIGALRM信號
# 信號都是發(fā)送給調(diào)用 進(jìn)程。
一下是連接參考 itimer 的使用方法:
linux上定時函數(shù) setitimer 的使用介紹
setitimer()為Linux的API,并非C語言的Standard Library,setitimer()有兩個功能,一是指定一段時間后,才執(zhí)行某個function,二是每間格一段時間就執(zhí)行某個function,以下程序demo如何使用setitimer()。
#include <stdio.h> // for printf()
#include <unistd.h> // for pause()
#include <signal.h> // for signal()
#include <string.h> // for memset()
#include <sys/time.h> // struct itimeral. setitimer()
void printMsg(int);
int main()
{
// Get system call result to determine successful or failed
int res = 0;
// Register printMsg to SIGALRM
signal(SIGALRM, printMsg);
struct itimerval tick;
// Initialize struct
memset(&tick, 0, sizeof(tick));
// Timeout to run function first time
tick.it_value.tv_sec = 1; // sec
tick.it_value.tv_usec = 0; // micro sec.
// Interval time to run function
tick.it_interval.tv_sec = 1;
tick.it_interval.tv_usec = 0;
// Set timer, ITIMER_REAL : real-time to decrease timer,
// send SIGALRM when timeout
res = setitimer(ITIMER_REAL, &tick, NULL);
if (res)
{
printf(”Set timer failed!!\n”);
}
// Always sleep to catch SIGALRM signal
while (1)
{
pause();
}
return 0;
}
void printMsg(int num)
{
printf(”%s”, “Hello World!!\n”);
}
當(dāng)setitimer()所執(zhí)行的timer時間到了,會呼叫SIGALRM signal,所以在第30行用signal()將要執(zhí)行的function指定給SIGALRM。
在第43行呼叫setitimer()設(shè)定timer,但setitimer()第二個參數(shù)是sturct,負(fù)責(zé)設(shè)定timeout時間,所以第 36行到第 40行設(shè)定此struct。itimerval.it_value設(shè)定第一次執(zhí)行function所延遲的秒數(shù), itimerval.it_interval設(shè)定以后每幾秒執(zhí)行function,所以若只想延遲一段時間執(zhí)行function,只要設(shè)定 itimerval.it_value即可,若要設(shè)定間格一段時間就執(zhí)行function,則it_value和it_interval都要設(shè)定,否則 funtion的第一次無法執(zhí)行,就別說以后的間隔執(zhí)行了。
第36行和第39行的tv_sec為sec,第37行和40行為micro sec(0.001 sec)。
第43行的第一個參數(shù)ITIMER_REAL,表示以real-time方式減少timer,在timeout時會送出SIGALRM signal。第三個參數(shù)會存放舊的timeout值,如果不需要的話,指定NULL即可。
第47 行的pause(),命令系統(tǒng)進(jìn)入sleep狀態(tài),等待任何signal,一定要用while(1)無窮循環(huán)執(zhí)行pause(),如此才能一直接收 SIGALRM signal以間隔執(zhí)行function,若拿掉while(1),則function只會執(zhí)行一次而已。
原文地址 http://www.cnblogs.com/oomusou/archive/2006/11/25/572246.html
【getitimer/setitimer系統(tǒng)調(diào)用】
功能描述:
獲取或設(shè)定間歇計(jì)時器的值。系統(tǒng)為進(jìn)程提供三種類型的計(jì)時器,每一類以不同的時間域遞減其值。當(dāng)計(jì)時器超時,信號被發(fā)送到進(jìn)程,之后計(jì)時器重啟動。
用法:
#include <sys/time.h>
int getitimer(int which, struct itimerval *value);
int setitimer(int which, const struct itimerval *value, struct itimerval *ovalue);
參數(shù):
which:間歇計(jì)時器類型,有三種選擇
ITIMER_REAL //數(shù)值為0,計(jì)時器的值實(shí)時遞減,發(fā)送的信號是SIGALRM。
ITIMER_VIRTUAL //數(shù)值為1,進(jìn)程執(zhí)行時遞減計(jì)時器的值,發(fā)送的信號是SIGVTALRM。
ITIMER_PROF //數(shù)值為2,進(jìn)程和系統(tǒng)執(zhí)行時都遞減計(jì)時器的值,發(fā)送的信號是SIGPROF。
value,ovalue:時間參數(shù),原型如下
struct itimerval {
struct timeval it_interval; /* 計(jì)時器重啟動的間歇值 */
struct timeval it_value; /* 計(jì)時器安裝后首先啟動的初始值 */
};
struct timeval {
long tv_sec; /* 秒 */
long tv_usec; /* 微妙(1/1000000) */
};
getitimer()用計(jì)時器的當(dāng)前值填寫value指向的結(jié)構(gòu)體。
setitimer()將value指向的結(jié)構(gòu)體設(shè)為計(jì)時器的當(dāng)前值,如果ovalue不是NULL,將返回計(jì)時器原有值。
返回說明:
成功執(zhí)行時,返回0。失敗返回-1,errno被設(shè)為以下的某個值
EFAULT:value或ovalue是不有效的指針
EINVAL:其值不是ITIMER_REAL,ITIMER_VIRTUAL 或 ITIMER_PROF之一
---------------------------------------------------------------------------------