程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> 關於C語言 >> Linux下C編程:setitimer

Linux下C編程:setitimer

編輯:關於C語言

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

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved