最近內部有個考試,提到 異步IO實現更精確定時器的題目,讓我比較迷惑。由此開始尋找資料,想分析一下。
誰知幾年不研究了,發現好多函數類似的,讓人頭暈。先就把一些函數列出來,等以后慢慢學習之吧。
sleep, usleep, nanosleep(AIX unix man里沒有,可是可以使用): 同步等待
alarm, ualarm: 異步信號通知
settimer, setitimer: 異步信號通知,
select : 精確到10ms(毫秒)級的 定時。
aio 異步通知: 還不確定怎么使用。
----------------------------------------------------------------------------------
- setitimer 比較 alarm
不同: setitimer 可以設置第一次的調用間隔時間,可能有些好處,如希望第一次信號 發生時已經完成了一些系統初始化的工作 ,而這些工作最好不要有信號發生。
相同: # 觸發方式: 都是 發送 SIGALRM信號
# 信號都是發送給調用 進程。
一下是連接參考 itimer 的使用方法:
linux上定時函數 setitimer 的使用介紹
setitimer()為Linux的API,并非C語言的Standard Library,setitimer()有兩個功能,一是指定一段時間后,才執行某個function,二是每間格一段時間就執行某個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”);
}
當setitimer()所執行的timer時間到了,會呼叫SIGALRM signal,所以在第30行用signal()將要執行的function指定給SIGALRM。
在第43行呼叫setitimer()設定timer,但setitimer()第二個參數是sturct,負責設定timeout時間,所以第 36行到第 40行設定此struct。itimerval.it_value設定第一次執行function所延遲的秒數, itimerval.it_interval設定以后每幾秒執行function,所以若只想延遲一段時間執行function,只要設定 itimerval.it_value即可,若要設定間格一段時間就執行function,則it_value和it_interval都要設定,否則 funtion的第一次無法執行,就別說以后的間隔執行了。
第36行和第39行的tv_sec為sec,第37行和40行為micro sec(0.001 sec)。
第43行的第一個參數ITIMER_REAL,表示以real-time方式減少timer,在timeout時會送出SIGALRM signal。第三個參數會存放舊的timeout值,如果不需要的話,指定NULL即可。
第47 行的pause(),命令系統進入sleep狀態,等待任何signal,一定要用while(1)無窮循環執行pause(),如此才能一直接收 SIGALRM signal以間隔執行function,若拿掉while(1),則function只會執行一次而已。
原文地址 http://www.cnblogs.com/oomusou/archive/2006/11/25/572246.html
【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 {
long tv_sec; /* 秒 */
long tv_usec; /* 微妙(1/1000000) */
};
getitimer()用計時器的當前值填寫value指向的結構體。
setitimer()將value指向的結構體設為計時器的當前值,如果ovalue不是NULL,將返回計時器原有值。
返回說明:
成功執行時,返回0。失敗返回-1,errno被設為以下的某個值
EFAULT:value或ovalue是不有效的指針
EINVAL:其值不是ITIMER_REAL,ITIMER_VIRTUAL 或 ITIMER_PROF之一
---------------------------------------------------------------------------------