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

            vc定時用法

            VC 中的定時

            VC中提供了很多關(guān)于時間操作的函數(shù),編寫程序時我們可以跟據(jù)定時的不同精度要求選擇不同的時間函數(shù)來完成定時和計(jì)時操作。
              
                 方式一:VC中的WM_TIMER消息映射能進(jìn)行簡單的時間控制。首先調(diào)用函數(shù)SetTimer()設(shè)置定時間隔,如SetTimer(0,200,NULL)即為設(shè)置200ms的時間間隔。然后在應(yīng)用程序中增加定時響應(yīng)函數(shù) OnTimer(),并在該函數(shù)中添加響應(yīng)的處理語句,用來完成到達(dá)定時時間的操作。這種定時方法非常簡單,可以實(shí)現(xiàn)一定的定時功能,但其定時功能如同Sleep()函數(shù)的延時功能一樣,精度非常低,最小計(jì)時精度僅為18ms。CPU占用低,且定時器消息在多任務(wù)操作系統(tǒng)中的優(yōu)先級很低,不能得到及時響應(yīng),往往不能滿足實(shí)時控制環(huán)境下的應(yīng)用。只可以用來實(shí)現(xiàn)諸如位圖的動態(tài)顯示等對定時精度要求不高的情況。

              方式二:VC中使用sleep()函數(shù)實(shí)現(xiàn)延時,它的單位是ms,如延時2秒,用sleep(2000)。精度非常低,最小計(jì)時精度僅為30ms,用sleep函數(shù)的不利處在于延時期間不能處理其他的消息,如果時間太長,就好象死機(jī)一樣,CPU占用率非常高,只能用于要求不高的延時程序中。

              方式三:利用COleDateTime類和COleDateTimeSpan類結(jié)合WINDOWS的消息處理過程來實(shí)現(xiàn)秒級延時。以下是實(shí)現(xiàn)2秒的延時代碼:

                 COleDateTime      start_time = COleDateTime::GetCurrentTime();
                 COleDateTimeSpan end_time= COleDateTime::GetCurrentTime()-start_time;
                 while(end_time.GetTotalSeconds()< 2) //實(shí)現(xiàn)延時2秒
                {
                         MSG   msg;
                         GetMessage(&msg,NULL,0,0);
                         TranslateMessage(&msg);
                         DispatchMessage(&msg);
                         
                        //以上四行是實(shí)現(xiàn)在延時或定時期間能處理其他的消息,
                 //雖然這樣可以降低CPU的占有率,
                        //但降低了延時或定時精度,實(shí)際應(yīng)用中可以去掉。
                        end_time = COleDateTime::GetCurrentTime()-start_time;
                 }//這樣在延時的時候我們也能夠處理其他的消息。      

              方式四:在精度要求較高的情況下,VC中可以利用GetTickCount()函數(shù),該函數(shù)的返回值是 DWORD型,表示以ms為單位的計(jì)算機(jī)啟動后經(jīng)歷的時間間隔。精度比WM_TIMER消息映射高,在較短的定時中其計(jì)時誤差為15ms,在較長的定時中其計(jì)時誤差較低,如果定時時間太長,就好象死機(jī)一樣,CPU占用率非常高,只能用于要求不高的延時程序中。下列代碼可以實(shí)現(xiàn)50ms的精確定時:
                  DWORD dwStart = GetTickCount();
                  DWORD dwEnd   = dwStart;
                  do
                  {
                     dwEnd = GetTickCount() - dwStart;
                  }while(dwEnd <50);
            為使GetTickCount()函數(shù)在延時或定時期間能處理其他的消息,可以把代碼改為:
                  DWORD dwStart = GetTickCount();
                  DWORD dwEnd   = dwStart;
                  do
                  {
                         MSG   msg;
                         GetMessage(&msg,NULL,0,0);
                         TranslateMessage(&msg);
                         DispatchMessage(&msg);
                         dwEnd = GetTickCount()-dwStart;
                  }while(dwEnd <50);
            雖然這樣可以降低CPU的占有率,并在延時或定時期間也能處理其他的消息,但降低了延時或定時精度。

              方式五:與GetTickCount()函數(shù)類似的多媒體定時器函數(shù)DWORD timeGetTime(void),該函數(shù)定時精度為ms級,返回從Windows啟動開始經(jīng)過的毫秒數(shù)。微軟公司在其多媒體Windows中提供了精確定時器的底層API持,利用多媒體定時器可以很精確地讀出系統(tǒng)的當(dāng)前時間,并且能在非常精確的時間間隔內(nèi)完成一個事件、函數(shù)或過程的調(diào)用。不同之處在于調(diào)用DWORD timeGetTime(void) 函數(shù)之前必須將 Winmm.lib 和 Mmsystem.h 添加到工程中,否則在編譯時提示DWORD timeGetTime(void)函數(shù)未定義。由于使用該函數(shù)是通過查詢的方式進(jìn)行定時控制的,所以,應(yīng)該建立定時循環(huán)來進(jìn)行定時事件的控制。

              方式六:使用多媒體定時器timeSetEvent()函數(shù),該函數(shù)定時精度為ms級。利用該函數(shù)可以實(shí)現(xiàn)周期性的函數(shù)調(diào)用。函數(shù)的原型如下:
                  MMRESULT timeSetEvent( UINT uDelay,
                                          UINT uResolution,
                                          LPTIMECALLBACK lpTimeProc,
                                          WORD dwUser,
                                          UINT fuEvent )
              該函數(shù)設(shè)置一個定時回調(diào)事件,此事件可以是一個一次性事件或周期性事件。事件一旦被激活,便調(diào)用指定的回調(diào)函數(shù),成功后返回事件的標(biāo)識符代碼,否則返回NULL。函數(shù)的參數(shù)說明如下:
                  uDelay:以毫秒指定事件的周期。
                  Uresolution:以毫秒指定延時的精度,數(shù)值越小定時器事件分辨率越高。缺省值為1ms。
                  LpTimeProc:指向一個回調(diào)函數(shù)。
                  DwUser:存放用戶提供的回調(diào)數(shù)據(jù)。
                  FuEvent:指定定時器事件類型:
                  TIME_ONESHOT:uDelay毫秒后只產(chǎn)生一次事件
                  TIME_PERIODIC :每隔uDelay毫秒周期性地產(chǎn)生事件。      

              具體應(yīng)用時,可以通過調(diào)用timeSetEvent()函數(shù),將需要周期性執(zhí)行的任務(wù)定義在LpTimeProc回調(diào)函數(shù)中(如:定時采樣、控制等),從而完成所需處理的事件。需要注意的是,任務(wù)處理的時間不能大于周期間隔時間。另外,在定時器使用完畢后,應(yīng)及時調(diào)用timeKillEvent()將之釋放。

              方式七:對于精確度要求更高的定時操作,則應(yīng)該使用QueryPerformanceFrequency()和 QueryPerformanceCounter()函數(shù)。這兩個函數(shù)是VC提供的僅供Windows 95及其后續(xù)版本使用的精確時間函數(shù),并要求計(jì)算機(jī)從硬件上支持精確定時器。

                 QueryPerformanceFrequency()函數(shù)和QueryPerformanceCounter()函數(shù)的原型如下:
                  BOOL QueryPerformanceFrequency(LARGE_INTEGER *lpFrequency);
                  BOOL QueryPerformanceCounter(LARGE_INTEGER *lpCount);
              數(shù)據(jù)類型ARGE_INTEGER既可以是一個8字節(jié)長的整型數(shù),也可以是兩個4字節(jié)長的整型數(shù)的聯(lián)合結(jié)構(gòu),其具體用法根據(jù)編譯器是否支持64位而定。該類型的定義如下:
                  typedef union _LARGE_INTEGER
                  {
                      struct
                      {
                         DWORD LowPart ;// 4字節(jié)整型數(shù)
                         LONG HighPart;// 4字節(jié)整型數(shù)
                      };
                      LONGLONG QuadPart ;// 8字節(jié)整型數(shù)
                      
                   }LARGE_INTEGER ;
              
                 在進(jìn)行定時之前,先調(diào)用QueryPerformanceFrequency()函數(shù)獲得機(jī)器內(nèi)部定時器的時鐘頻率,然后在需要嚴(yán)格定時的事件發(fā)生之前和發(fā)生之后分別調(diào)用QueryPerformanceCounter()函數(shù),利用兩次獲得的計(jì)數(shù)之差及時鐘頻率,計(jì)算出事件經(jīng)歷的精確時間。下列代碼實(shí)現(xiàn)1ms的精確定時:
                  LARGE_INTEGER litmp;
                  LONGLONG QPart1,QPart2;
                  double dfMinus, dfFreq, dfTim;
                  QueryPerformanceFrequency(&litmp);
                  dfFreq = (double)litmp.QuadPart;// 獲得計(jì)數(shù)器的時鐘頻率
                  QueryPerformanceCounter(&litmp);
                  QPart1 = litmp.QuadPart;// 獲得初始值
                  do
                  {
                     QueryPerformanceCounter(&litmp);
                     QPart2 = litmp.QuadPart;//獲得中止值
                     dfMinus = (double)(QPart2-QPart1);
                     dfTim = dfMinus / dfFreq;// 獲得對應(yīng)的時間值,單位為秒
                  }while(dfTim<0.001);

            posted on 2008-10-25 09:15 wrh 閱讀(1597) 評論(0)  編輯 收藏 引用


            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            導(dǎo)航

            <2008年10月>
            2829301234
            567891011
            12131415161718
            19202122232425
            2627282930311
            2345678

            統(tǒng)計(jì)

            常用鏈接

            留言簿(19)

            隨筆檔案

            文章檔案

            收藏夾

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            美女久久久久久| 亚洲一本综合久久| 亚洲伊人久久综合影院| 日本亚洲色大成网站WWW久久| 青青草原综合久久大伊人导航| 久久久久久久精品成人热色戒| 精品久久8x国产免费观看| 97r久久精品国产99国产精| 91久久精品无码一区二区毛片| 亚洲国产高清精品线久久 | 99精品国产在热久久无毒不卡| 久久777国产线看观看精品| 人妻精品久久久久中文字幕| 久久夜色精品国产噜噜麻豆| 日本久久久久久久久久| 99久久成人国产精品免费| 热RE99久久精品国产66热| 国产精品久久久久影视不卡| 无码任你躁久久久久久老妇App| 久久精品国产亚洲77777| 亚洲精品NV久久久久久久久久| 91精品国产乱码久久久久久| 亚洲精品乱码久久久久久自慰| 国内精品久久久久久久久电影网 | 精品水蜜桃久久久久久久| 久久夜色精品国产噜噜噜亚洲AV| 人妻少妇精品久久| 精品久久久久久无码国产| 久久91精品久久91综合| 婷婷久久久亚洲欧洲日产国码AV| 久久笫一福利免费导航 | 色综合久久久久久久久五月| 模特私拍国产精品久久| 伊人久久大香线蕉AV一区二区| 精品久久久久久无码免费| 久久久精品国产亚洲成人满18免费网站| 久久亚洲精品成人AV| 日韩精品久久无码人妻中文字幕| 久久永久免费人妻精品下载| 无码人妻久久久一区二区三区| 精品久久久久久国产|