setitimer:和alarm相似,但可以更精確的控制進程。which表示計時方式。value和oldvalue是指向itmerval指標。setitimer()調用成功返回0,否則返回-1。
which取值:
ITIMER_REAL : 以系統真實的時間來計算,它送出SIGALRM訊號。
ITIMER_VIRTUAL : 以該進程在使用者態下花費的時間來計算,它送出SIGVTALRM訊號。
ITIMER_PROF : 以該進程在使用者態下和核心態下所費的時間來計算,它送出SIGPROF訊號。
itimerval在linux2.6.39/include/linux/time.h中實現。
struct itimerval { struct timeval it_interval; /* timerinterval */ struct timeval it_value; /* currentvalue */ };
itimerval結構中的it_value是減少的時間,當這個值為0的時候就發出相應的訊號了. 然後再將it_value設定為it_interval值.
註:
Linux訊號機制基本上是從Unix系統中繼承過來的。早期Unix系統中的訊號機制比較簡單和原始,後來在實踐中暴露出一些問題,因此,把那些建立在早期機制上的訊號叫做"不可靠訊號",訊號值小於SIGRTMIN(SIGRTMIN=32,SIGRTMAX=63)的訊號都是不可靠訊號。這就是"不可靠訊號"的來源。它的主要問題是:進程每次處理訊號後,就將對訊號的響應設定為預設動作。在某些情況下,將導致對訊號的錯誤處理;因此,使用者如果不希望這樣的操作,那麼就要在訊號處理函數結尾再一次調用signal(),重新安裝該訊號。
執行個體如下:
#include <stdio.h> #include <sys/time.h> #include <signal.h> void func(int signumber); void main() { structitimerval value; signal(SIGALRM,&func); value.it_value.tv_sec= 1; value.it_value.tv_usec= 0; value.it_interval.tv_sec= 1; value.it_interval.tv_usec= 0; setitimer(ITIMER_REAL,&value,NULL); while(1) pause(); } void func(int signumber)//signumber是系統向此函數傳遞的訊號編號 { switch(signumber) { caseSIGALRM: printf("getSIGALRM\n"); signal(SIGALRM,&func); break; default: printf("nothing\n"); break; } }
查看全套文章:http://www.bianceng.cn/Programming/C/201212/34807.htm