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

            ---------------------------------------------------------------------------------
            精品久久人人爽天天玩人人妻| 久久久久久久久久久久久久| 国产免费久久久久久无码| 国产亚洲美女精品久久久| 亚洲综合日韩久久成人AV| 青青青国产精品国产精品久久久久| 亚洲精品视频久久久| …久久精品99久久香蕉国产| 欧美国产精品久久高清| 91精品久久久久久无码| 97精品伊人久久久大香线蕉| 99久久久久| 精品久久久无码人妻中文字幕豆芽| 久久伊人影视| 久久99精品国产麻豆蜜芽| 精品综合久久久久久97超人| 伊人久久大香线蕉av一区| 亚洲日本久久久午夜精品| 93精91精品国产综合久久香蕉| 色欲综合久久躁天天躁蜜桃| 日日狠狠久久偷偷色综合0| 国产国产成人久久精品| 久久夜色tv网站| 久久精品国产精品青草| 九九99精品久久久久久| 激情伊人五月天久久综合| 亚洲愉拍99热成人精品热久久| 亚洲国产精品成人AV无码久久综合影院 | 国内精品久久久久| 亚洲精品tv久久久久久久久| 久久只这里是精品66| 久久精品综合网| 久久久久久毛片免费看| 久久激情亚洲精品无码?V| 91精品国产91久久| 久久99精品久久久久久秒播| 国产精自产拍久久久久久蜜| 国内精品久久久久久不卡影院 | 国产精品免费久久久久电影网| 色综合久久精品中文字幕首页| 中文字幕亚洲综合久久|