青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆 - 224  文章 - 41  trackbacks - 0
<2008年11月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
30123456

享受編程

常用鏈接

留言簿(11)

隨筆分類(159)

隨筆檔案(224)

文章分類(2)

文章檔案(4)

經典c++博客

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

 

介紹

       我們在衡量一個函數運行時間,或者判斷一個算法的時間效率,或者在程序中我們需要一個定時器,定時執行一個特定的操作,比如在多媒體中,比如在游戲中等,都會用到時間函數。還比如我們通過記錄函數或者算法開始和截至的時間,然后利用兩者之差得出函數或者算法的運行時間。編譯器和操作系統為我們提供了很多時間函數,這些時間函數的精度也是各不相同的,所以,如果我們想得到準確的結果,必須使用合適的時間函數。現在我就介紹windows下的幾種常用時間函數。

1Sleep函數

使用:sleep(1000),在WindowsLinux1000代表的含義并不相同,Windows下的表示1000毫秒,也就是1秒鐘;Linux下表示1000秒,Linux下使用毫秒級別的函數可以使用usleep

原理:sleep函數是使調用sleep函數的線程休眠,線程主動放棄時間片。當經過指定的時間間隔后,再啟動線程,繼續執行代碼。Sleep函數并不能起到定時的作用,主要作用是延時。在一些多線程中可能會看到sleep(0);其主要目的是讓出時間片。

精度:sleep函數的精度非常低,當系統越忙它精度也就越低,有時候我們休眠1秒,可能3秒后才能繼續執行。它的精度取決于線程自身優先級、其他線程的優先級,以及線程的數量等因素。

2MFC下的timer事件

       使用:1.調用函數SetTimer()設置定時間隔,如SetTimer(0,100,NULL)即為設置100毫秒的時間間隔;2.在應用程序中增加定時響應函數OnTimer(),并在該函數中添加響應的處理語句,用來完成時間到時的操作。

    原理:同sleep函數一樣。不同的是timer是一個定時器,可以指定回調函數,默認為OnTimer()函數。

    精度:timer事件的精度范圍在毫米級別,系統越忙其精度也就越差。

3C語言下的Time

       使用:time_t t;time(&t);Time函數是獲取當前時間。

    原理:time函數主要用于獲取當前時間,比如我們做一個電子時鐘程序,就可以使用此函數,獲取系統當前的時間。

精度:秒級別

4COM對象中的COleDateTimeCOleDateTimeSpan

    使用:COleDateTime start_time = COleDateTime::GetCurrentTime();

COleDateTimeSpan end_time = COleDateTime::GetCurrentTime()-start_time;

While(end_time.GetTotalSeconds() < 2)

{

// 處理延時或定時期間能處理其他的消息

DoSomething()

end_time = COleDateTime::GetCurrentTime-start_time;

}

原理:以上代表延時2秒,而這兩秒內我們可以循環調用DoSomething(),從而實現在延時的時候我們也能夠處理其他的函數,或者消息。COleDateTime,COleDateTimeSpanMFCCTimeCTimeSpanCOM中的應用,所以,上面的方法對于CTimeCTimeSpa同樣有效。

       精度:秒級別

5C語言下的時鐘周期clock()

       使用:   clock_t start = clock();

              Sleep(100);

              clock_t end = clock();

          double d = (double)(start - end) / CLOCKS_PER_SEC;

       原理:clock()是獲取計算機啟動后的時間間隔。

精度:ms級別,對于短時間內的定時或者延時可以達到ms級別,對于時間比較長的定時或者延遲精度還是不夠。在windowsCLOCKS_PER_SEC1000

6Windows下的GetTickCount()

使用:  DWORD start = GetTickCount();

        Sleep(100);

        DWORD end = GetTickCount();

原理:GetTickCount()是獲取系統啟動后的時間間隔。通過進入函數開始定時,到退出函數結束定時,從而可以判斷出函數的執行時間,這種時間也并

非是函數或者算法的真實執行時間,因為在函數和算法線程不可能一直占用CPU,對于所有判斷執行時間的函數都是一樣,不過基本上已經很準確,可以通過查詢進行定時。GetTickCount()Clock()函數是向主板BIOSreal time clock時間,會有中斷產生,以及延遲問題。

精度:WindowsNT 3.5以及以后版本精度是10ms,它的時間精度比clock函數的要高,GetTickCount()常用于多媒體中。

7WindowstimeGetTime

使用:需要包含Mmsystem.hWindows.h,加入靜態庫Winmm.lib.

timeBeginPeriod(1);

DWORD start = timeGetTime();

              Sleep(100);

          DWORD end = timeGetTime();

timeEndPeriod(1);

原理:timeGetTime也時常用于多媒體定時器中,可以通過查詢進行定時。通過查詢進行定時,本身也會影響定時器的定時精度。

精度:毫秒,與GetTickCount()相當。但是和GetTickCount相比,timeGetTime可以通過timeBeginPeriodtimeEndPeriod設置定時器的最小解析精度, timeBeginPeriod,timeEndPeriod必須成對出現。

8windows下的timeSetEvent

使用:還記的VC下的Timer嗎?Timer是一個定時器,而以上我們提到幾種時間函數或者類型,實現定時功能只能通過輪訓來實現,也就是必須另外創建一個線程單獨處理,這樣會影響定時精度,好在windows提供了內置的定時器timeSetEvent,函數原型為

MMRESULT timeSetEvent UINT uDelay, //以毫秒指定事件的周期

UINT uResolution, //以毫秒指定延時的精度,數值越小定時器事件分辨率越高。缺省值為1ms

LPTIMECALLBACK lpTimeProc, //指向一個回調函數

WORD dwUser, //存放用戶提供的回調數據

UINT fuEvent // 標志參數,TIME_ONESHOT:執行一次;TIME_PERIODIC:周期性執行

       具體應用時,可以通過調用timeSetEvent()函數,將需要周期性執行的任務定義在 lpFunction回調函數中(如:定時采樣、控制等),從而完成所需處理的事件。需要注意的是:任務處理的時間不能大于周期間隔時間。另外,在定

 時器使用完畢后,應及時調用timeKillEvent()將之釋放。

原理:可以理解為代回調函數的timeGetTime

精度:毫秒,timeSetEvent可以通過timeBeginPeriodtimeEndPeriod設置定時器的最小解析精度, timeBeginPeriod,timeEndPeriod必須成對出現。

9:高精度時控函數QueryPerformanceFrequencyQueryPerformanceCounter

使用:LARGE_INTEGER m_nFreq;

          LARGE_INTEGER m_nBeginTime;

          LARGE_INTEGER nEndTime;

          QueryPerformanceFrequency(&m_nFreq); // 獲取時鐘周期

          QueryPerformanceCounter(&m_nBeginTime); // 獲取時鐘計數

          Sleep(100);

          QueryPerformanceCounter(&nEndTime);

     cout << (nEndTime.QuadPart-m_nBeginTime.QuadPart)*1000/m_nFreq.QuadPart << endl;

原理:CPU上也有一個計數器,以機器的clock為單位,可以通過rdtsc讀取,而不用中斷,因此其精度與系統時間相當。

精度:計算機獲取硬件支持,精度比較高,可以通過它判斷其他時間函數的精度范圍。

10小結:以上提到常用的9種時間函數,由于他們的用處不同,所以他們的精度也不盡相同,所以如果簡單的延時可以用sleep函數,稍微準確的延時可以使用clock函數,GetTickCount函數,更高級的實用timeGetTime函數;簡單的定時事件可以用Timer,準確地可以用timeSetEvent;或取一般系統時間可以通time,或者CTime,或者COleDateTime,獲取準確的時間可以用clock,或者GetTickCount函數,或者timeGetTime函數,而獲取準確地系統時間要使用硬件支持的QueryPerformanceFrequency函數,QueryPerformanceCounter函數。

CStopwatch.h

#include <windows.h>

class CStopwatch 
{
public:
    CStopwatch() 
    { 
        QueryPerformanceFrequency(
&m_liPerfFreq); 
        Start(); 
    }
    
    
void Start() 
    { 
        QueryPerformanceCounter(
&m_liPerfStart); 
    }
    
    
// Returns # of milliseconds since Start was called
    __int64 Now() const 
    {   
        LARGE_INTEGER liPerfNow;
        QueryPerformanceCounter(
&liPerfNow);
        
return(((liPerfNow.QuadPart - m_liPerfStart.QuadPart) * 1000/ m_liPerfFreq.QuadPart);
    }
private:
    LARGE_INTEGER m_liPerfFreq;   
// Counts per second
    LARGE_INTEGER m_liPerfStart;  // Starting count
};

使用:
// CStopwatchTest.cpp : Defines the entry point for the console application.
//

#include 
"stdafx.h"
#include 
"CStopwatch.h"

int main(int argc, char* argv[])
{
    CStopwatch stopWatch;
    
for(int i = 0; i < 10; i++)
    {
        
for(int j = 0; j < 10; j++)
        {
            
for(int z = 0; z < 10; z++)
            {
                Sleep(
1);
            }
        }
    }
    __int64 qwElapsedTime 
= stopWatch.Now();
    
return 0;
}
posted on 2008-11-15 16:17 漂漂 閱讀(870) 評論(0)  編輯 收藏 引用 所屬分類: visual studio
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            9久草视频在线视频精品| 国产欧美一区二区白浆黑人| 狠狠干狠狠久久| 亚洲自拍偷拍福利| 亚洲精品视频在线观看免费| 免费视频最近日韩| 亚洲国产经典视频| 欧美激情自拍| 精品二区视频| 欧美国产免费| 久久se精品一区精品二区| 9人人澡人人爽人人精品| 久久av免费一区| 亚洲欧美日韩国产精品| 欧美日韩第一区| 亚洲美女精品一区| 亚洲精品国产精品国自产在线| 久久综合中文| 亚洲高清在线播放| 久久久久久免费| 日韩视频免费观看高清在线视频| 欧美.www| 中文精品99久久国产香蕉| 日韩午夜免费| 国产精品欧美日韩一区| 久久精品成人| 欧美一区二区视频网站| 激情校园亚洲| 欧美激情一区二区久久久| 欧美精品电影在线| 亚洲专区一区二区三区| 先锋亚洲精品| 亚洲国产裸拍裸体视频在线观看乱了 | 玖玖玖国产精品| 亚洲一区二区三区精品视频| 国产日韩欧美自拍| 欧美国产极速在线| 欧美视频二区| 久久精品综合网| 欧美黄色aa电影| 正在播放亚洲一区| 欧美专区在线播放| 亚洲欧洲一区二区三区| 中文国产一区| ●精品国产综合乱码久久久久| 亚洲国产欧美一区二区三区丁香婷| 欧美激情中文字幕在线| 欧美在线播放| 欧美精品久久久久a| 久久精品视频99| 欧美精品一区二区三区蜜桃| 欧美一区二区三区精品| 欧美国产日韩一区二区| 欧美一区二区私人影院日本 | 久久国产99| 欧美国产视频日韩| 久久国产精品99国产| 欧美肥婆在线| 久久一区二区三区四区| 欧美日韩国产高清| 欧美韩日高清| 国产日韩欧美综合一区| 亚洲乱码国产乱码精品精98午夜 | 欧美在线在线| 亚洲国产视频a| 欧美在线免费观看| 亚洲摸下面视频| 欧美男人的天堂| 女人香蕉久久**毛片精品| 国产精品美女主播| 99爱精品视频| 一区视频在线看| 一本色道久久综合亚洲精品婷婷| 亚洲二区在线视频| 久久国产精品99精品国产| 中日韩男男gay无套| 欧美激情精品久久久久久免费印度 | 亚洲无玛一区| 欧美88av| 久久激情久久| 国产深夜精品| 亚洲欧美一区二区原创| 亚洲欧美美女| 国产精品免费久久久久久| 欧美黑人国产人伦爽爽爽| 国产日韩欧美在线| 亚洲欧美一级二级三级| 亚洲免费网站| 国产精品日韩在线一区| 亚洲一区二区在线| 欧美一区二区三区精品 | 欧美一区二区三区另类| 国产精品国产亚洲精品看不卡15 | 欧美精品在线免费播放| 亚洲精品国产精品久久清纯直播 | 亚洲国产高清在线观看视频| 欧美黄色精品| 亚洲在线一区| 伊人一区二区三区久久精品| 欧美精品网站| 午夜精品一区二区三区在线视| 久热精品视频在线观看| 一区二区三区黄色| 国产亚洲一区二区在线观看| 蜜臀久久久99精品久久久久久 | 亚洲在线观看| 在线观看精品视频| 欧美日本精品在线| 欧美一区二区三区四区在线观看地址 | av不卡在线| 国产麻豆视频精品| 欧美成人免费va影院高清| 亚洲视频福利| 亚洲电影av在线| 久久国产精品色婷婷| 一区二区日韩免费看| 精品动漫3d一区二区三区免费版| 欧美成人tv| 久久精品中文| 亚洲视频在线一区| 亚洲人成在线免费观看| 久久亚洲美女| 午夜精品一区二区三区在线视 | 日韩午夜av在线| 今天的高清视频免费播放成人| 国产精品成人在线| 欧美成人精品一区| 久久亚洲高清| 欧美综合二区| 午夜国产一区| 亚洲综合导航| 亚洲一区二区三区在线观看视频| 亚洲精品一区二区三区在线观看 | 亚洲综合国产| 亚洲网站在线| 亚洲视频视频在线| 99亚洲一区二区| 日韩一二三在线视频播| 亚洲人成在线观看一区二区| 国产综合香蕉五月婷在线| 国产欧美日韩综合精品二区| 国产精品日日摸夜夜添夜夜av| 欧美视频国产精品| 欧美日韩在线精品一区二区三区| 欧美日本高清视频| 欧美日韩免费网站| 欧美视频在线观看一区| 欧美亚韩一区| 国产精品免费福利| 国产女人18毛片水18精品| 国产精品国产| 国产欧美日韩伦理| 国产一区二区三区观看| 国内精品国产成人| 亚洲第一区在线| 91久久精品久久国产性色也91| 亚洲国产高清aⅴ视频| 亚洲人成网站色ww在线| 亚洲精品免费一二三区| 在线亚洲美日韩| 欧美亚洲一级片| 久久噜噜亚洲综合| 欧美大片国产精品| 99精品欧美一区二区三区 | 久久久久九九九九| 快射av在线播放一区| 亚洲国产精品一区制服丝袜| 日韩小视频在线观看| 亚洲综合精品| 巨乳诱惑日韩免费av| 欧美人与性动交cc0o| 国产精品永久免费在线| 一区二区三区在线免费视频| 亚洲精品美女在线观看播放| 亚洲欧美日韩国产中文在线| 久久久噜噜噜久久久| 亚洲电影天堂av| 亚洲男女自偷自拍图片另类| 久久精品欧美| 欧美日韩另类国产亚洲欧美一级| 国产欧美日韩另类一区| 亚洲国产一区二区在线| 亚洲欧美怡红院| 猫咪成人在线观看| 99精品欧美一区二区三区| 久久精品久久99精品久久| 欧美日韩国产亚洲一区| 激情丁香综合| 午夜免费在线观看精品视频| 欧美成人综合| 欧美一级视频免费在线观看| 欧美国产一区二区| 国内一区二区在线视频观看| 一区二区三区欧美视频| 欧美91大片| 欧美在线观看天堂一区二区三区 | 欧美一级成年大片在线观看| 欧美激情精品久久久久久大尺度 | 欧美日本一区二区视频在线观看 | 欧美色精品天天在线观看视频|