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; } }