• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Prayer

            在一般中尋求卓越
            posts - 1256, comments - 190, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            關于時間的一些函數(定時器)

            Posted on 2009-02-04 18:08 Prayer 閱讀(1050) 評論(0)  編輯 收藏 引用 所屬分類: LINUX/UNIX/AIX
            最近內部有個考試,提到 異步IO實現更精確定時器的題目,讓我比較迷惑。由此開始尋找資料,想分析一下。

            誰知幾年不研究了,發現好多函數類似的,讓人頭暈。先就把一些函數列出來,等以后慢慢學習之吧。

            sleep, usleep, nanosleep(AIX unix man里沒有,可是可以使用):  同步等待

            alarm, ualarm: 異步信號通知

            settimer, setitimer: 異步信號通知,

            select : 精確到10ms(毫秒)級的 定時。

            aio 異步通知: 還不確定怎么使用。

            ----------------------------------------------------------------------------------
            1. setitimer 比較 alarm
             不同: setitimer 可以設置第一次的調用間隔時間,可能有些好處,如希望第一次信號 發生時已經完成了一些系統初始化的工作 ,而這些工作最好不要有信號發生。
              相同: # 觸發方式: 都是 發送 SIGALRM信號
                    # 信號都是發送給調用 進程。
             
            一下是連接參考 itimer 的使用方法:

            linux上定時函數 setitimer 的使用介紹

            8月 28, 2008 · Filed Under Techonologies, Web log related, 資料 

            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之一

            ---------------------------------------------------------------------------------
            亚洲中文字幕久久精品无码喷水| 久久精品国产亚洲精品2020| 久久国产一区二区| 99久久99这里只有免费费精品| 狠狠色丁香久久综合婷婷| 国产成人久久精品麻豆一区| 久久久久久久亚洲精品| 亚洲午夜久久久久妓女影院| 99麻豆久久久国产精品免费 | 国产婷婷成人久久Av免费高清| 久久精品欧美日韩精品| 国产成人久久久精品二区三区| 青青草国产97免久久费观看| 久久综合香蕉国产蜜臀AV| 亚洲国产精品久久| 中文字幕乱码久久午夜| 国产日韩久久久精品影院首页| 亚洲人成电影网站久久| 99久久精品午夜一区二区| 亚洲欧洲中文日韩久久AV乱码| 狠狠狠色丁香婷婷综合久久五月| 久久天天日天天操综合伊人av| 欧美午夜精品久久久久免费视 | 99久久综合国产精品免费| 久久国产精品99国产精| 精品国产乱码久久久久久人妻| 99久久成人国产精品免费| 久久人人爽人人爽人人爽| 国产无套内射久久久国产| 国产精品久久久久…| 无遮挡粉嫩小泬久久久久久久| 污污内射久久一区二区欧美日韩| 久久久久久国产精品免费无码 | 国产欧美久久一区二区| 久久香综合精品久久伊人| AV无码久久久久不卡蜜桃| 久久成人小视频| 久久久国产视频| 欧美日韩精品久久久久| 久久久久久久91精品免费观看| 一97日本道伊人久久综合影院|