亚洲韩日午夜视频,欧美日韩在线精品一区二区三区,韩国超清无码一区二区三区,亚洲国产成人影院播放,久草新在线,在线看片AV色

您好,歡迎來到思海網絡,我們將竭誠為您提供優質的服務! 誠征網絡推廣 | 網站備案 | 幫助中心 | 軟件下載 | 購買流程 | 付款方式 | 聯系我們 [ 會員登錄/注冊 ]
促銷推廣
客服中心
業務咨詢
有事點擊這里…  531199185
有事點擊這里…  61352289
點擊這里給我發消息  81721488
有事點擊這里…  376585780
有事點擊這里…  872642803
有事點擊這里…  459248018
有事點擊這里…  61352288
有事點擊這里…  380791050
技術支持
有事點擊這里…  714236853
有事點擊這里…  719304487
有事點擊這里…  1208894568
有事點擊這里…  61352289
在線客服
有事點擊這里…  531199185
有事點擊這里…  61352288
有事點擊這里…  983054746
有事點擊這里…  893984210
當前位置:首頁 >> 技術文章 >> 文章瀏覽
技術文章

Linux下定時器使用

添加時間:2011-5-12  添加: admin 

Linux下的定時器有兩種,以下分別介紹:

       1、alarm
       如果不要求很精確的話,用 alarm() 和 signal() 就夠了
           unsigned int alarm(unsigned int seconds)
       專門為SIGALRM信號而設,在指定的時間seconds秒后,將向進程本身發送SIGALRM信號,又稱為鬧鐘時間。進程調用alarm后,任何以前的alarm()調用都將無效。如果參數seconds為零,那么進程內將不再包含任何鬧鐘時間。如果調用alarm()前,進程中已經設置了鬧鐘時間,則返回上一個鬧鐘時間的剩余時間,否則返回0。

       示例:
       #include <stdio.h>
       #include <unistd.h>
       #include <signal.h>

       void sigalrm_fn(int sig)
       {
               /* Do something */
               printf("alarm!\n");

               alarm(2);
               return;
       }

       int main(void)
       {
               signal(SIGALRM, sigalrm_fn);
               alarm(2);

               /* Do someting */
               while(1) pause();
       }


       2、setitimer
       int setitimer(int which, const struct itimerval *value, struct itimerval *ovalue));
       setitimer()比alarm功能強大,支持3種類型的定時器:

       ITIMER_REAL :  以系統真實的時間來計算,它送出SIGALRM信號。  
       ITIMER_VIRTUAL :  以該行程真正有執行的時間來計算,它送出SIGVTALRM信號。  
       ITIMER_PROF :  以行程真正有執行及在核心中所費的時間來計算,它送出SIGPROF信號。  
       Setitimer()第一個參數which指定定時器類型(上面三種之一);第二個參數是結構itimerval的一個實例;第三個參數可不做處理。
       Setitimer()調用成功返回0,否則返回-1。

       下面是關于setitimer調用的一個簡單示范,在該例子中,每隔一秒發出一個SIGALRM,每隔0.5秒發出一個SIGVTALRM信號::
       #include <stdio.h>
       #include <stdlib.h>
       #include <unistd.h>
       #include <signal.h>
       #include <time.h>
       #include <sys/time.h>

       int sec;
       void sigroutine(int signo){

           switch (signo){
           case SIGALRM:
               printf("Catch a signal -- SIGALRM \n");
               signal(SIGALRM, sigroutine);
               break;
           case SIGVTALRM:
               printf("Catch a signal -- SIGVTALRM \n");
               signal(SIGVTALRM, sigroutine);
               break;
           }
           return;
       }

       int main()
       {
           struct itimerval value, ovalue, value2;
   
           sec = 5;
           printf("process id is %d ", getpid());
           signal(SIGALRM, sigroutine);
           signal(SIGVTALRM, sigroutine);
           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, &ovalue);

           value2.it_value.tv_sec = 0;
           value2.it_value.tv_usec = 500000;
           value2.it_interval.tv_sec = 0;
           value2.it_interval.tv_usec = 500000;
           setitimer(ITIMER_VIRTUAL, &value2, &ovalue);
           for(;;)
               ;
       }


        該例子的屏幕拷貝如下:

       localhost:~$ ./timer_test
       process id is 579
       Catch a signal – SIGVTALRM
       Catch a signal – SIGALRM
       Catch a signal – SIGVTALRM
       Catch a signal – SIGVTALRM
       Catch a signal – SIGALRM
       Catch a signal –GVTALRM


       注意:Linux信號機制基本上是從Unix系統中繼承過來的。早期Unix系統中的信號機制比較簡單和原始,后來在實踐中暴露出一些問題,因此,把那些建立在早期機制上的信號叫做"不可靠信號",信號值小于SIGRTMIN(Red hat 7.2中,SIGRTMIN=32,SIGRTMAX=63)的信號都是不可靠信號。這就是"不可靠信號"的來源。它的主要問題是:進程每次處理信號后,就將對信號的響應設置為默認動作。在某些情況下,將導致對信號的錯誤處理;因此,用戶如果不希望這樣的操作,那么就要在信號處理函數結尾再一次調用signal(),重新安裝該信號。

關鍵字:定時器、系統、信號

分享到:

頂部 】 【 關閉
版權所有:佛山思海電腦網絡有限公司 ©1998-2024 All Rights Reserved.
聯系電話:(0757)22630313、22633833
中華人民共和國增值電信業務經營許可證: 粵B1.B2-20030321 備案號:粵B2-20030321-1
網站公安備案編號:44060602000007 交互式欄目專項備案編號:200303DD003  
察察 工商 網安 舉報有獎  警警  手機打開網站