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

隨筆 - 224  文章 - 41  trackbacks - 0
<2010年4月>
28293031123
45678910
11121314151617
18192021222324
2526272829301
2345678

享受編程

常用鏈接

留言簿(11)

隨筆分類(159)

隨筆檔案(224)

文章分類(2)

文章檔案(4)

經(jīng)典c++博客

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

 

介紹

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

1Sleep函數(shù)

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

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

精度:sleep函數(shù)的精度非常低,當(dāng)系統(tǒng)越忙它精度也就越低,有時候我們休眠1秒,可能3秒后才能繼續(xù)執(zhí)行。它的精度取決于線程自身優(yōu)先級、其他線程的優(yōu)先級,以及線程的數(shù)量等因素。

2MFC下的timer事件

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

    原理:同sleep函數(shù)一樣。不同的是timer是一個定時器,可以指定回調(diào)函數(shù),默認(rèn)為OnTimer()函數(shù)。

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

3C語言下的Time

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

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

精度:秒級別

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秒,而這兩秒內(nèi)我們可以循環(huán)調(diào)用DoSomething(),從而實(shí)現(xiàn)在延時的時候我們也能夠處理其他的函數(shù),或者消息。COleDateTime,COleDateTimeSpanMFCCTimeCTimeSpanCOM中的應(yīng)用,所以,上面的方法對于CTimeCTimeSpa同樣有效。

       精度:秒級別

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

       使用:   clock_t start = clock();

              Sleep(100);

              clock_t end = clock();

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

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

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

6Windows下的GetTickCount()

使用:  DWORD start = GetTickCount();

        Sleep(100);

        DWORD end = GetTickCount();

原理:GetTickCount()是獲取系統(tǒng)啟動后的時間間隔。通過進(jìn)入函數(shù)開始定時,到退出函數(shù)結(jié)束定時,從而可以判斷出函數(shù)的執(zhí)行時間,這種時間也并

非是函數(shù)或者算法的真實(shí)執(zhí)行時間,因?yàn)樵诤瘮?shù)和算法線程不可能一直占用CPU,對于所有判斷執(zhí)行時間的函數(shù)都是一樣,不過基本上已經(jīng)很準(zhǔn)確,可以通過查詢進(jìn)行定時。GetTickCount()Clock()函數(shù)是向主板BIOSreal time clock時間,會有中斷產(chǎn)生,以及延遲問題。

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

7WindowstimeGetTime

使用:需要包含Mmsystem.hWindows.h,加入靜態(tài)庫Winmm.lib.

timeBeginPeriod(1);

DWORD start = timeGetTime();

              Sleep(100);

          DWORD end = timeGetTime();

timeEndPeriod(1);

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

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

8windows下的timeSetEvent

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

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

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

LPTIMECALLBACK lpTimeProc, //指向一個回調(diào)函數(shù)

WORD dwUser, //存放用戶提供的回調(diào)數(shù)據(jù)

UINT fuEvent // 標(biāo)志參數(shù),TIME_ONESHOT:執(zhí)行一次;TIME_PERIODIC:周期性執(zhí)行

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

 時器使用完畢后,應(yīng)及時調(diào)用timeKillEvent()將之釋放。

原理:可以理解為代回調(diào)函數(shù)的timeGetTime

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

9:高精度時控函數(shù)QueryPerformanceFrequencyQueryPerformanceCounter

使用:LARGE_INTEGER m_nFreq;

          LARGE_INTEGER m_nBeginTime;

          LARGE_INTEGER nEndTime;

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

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

          Sleep(100);

          QueryPerformanceCounter(&nEndTime);

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

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

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

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

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>
            亚洲精品国产精品国自产观看浪潮| 久久精品国产精品亚洲综合| 亚洲黄网站在线观看| 国产精品久久久久影院色老大| 麻豆精品一区二区综合av| 久久天天综合| 免费久久99精品国产自| 欧美日韩精品久久| 欧美日韩直播| 国产一区二区按摩在线观看| 伊人久久亚洲影院| 日韩视频免费大全中文字幕| 亚洲视屏在线播放| 先锋资源久久| 亚洲欧美日韩直播| 久久精品中文字幕一区| 你懂的视频一区二区| 99国产精品99久久久久久| 亚洲综合成人在线| 欧美精品一区二区精品网| 国产精品美女诱惑| 一区二区三区免费网站| 男女精品网站| 午夜视频在线观看一区| 欧美日韩国产黄| 亚洲乱码国产乱码精品精| 久久精品一区二区| 欧美一区二区精品久久911| 欧美日韩国产区| 亚洲欧洲综合另类| 亚洲国产高潮在线观看| 久久只精品国产| 亚洲第一二三四五区| 免费欧美视频| 欧美在线观看一区二区| 在线亚洲观看| 欧美视频免费| 久久国产日韩| 欧美在线一级va免费观看| 黑人巨大精品欧美一区二区小视频| 欧美一区二区啪啪| 午夜精品久久久久久99热软件| 国产毛片久久| 欧美大片一区| 国产精品海角社区在线观看| 亚洲欧美在线播放| 久久精品网址| 免费在线成人av| 亚洲一区二区三区四区视频| 亚洲尤物视频在线| 91久久精品美女| 亚洲网站啪啪| 亚洲国产日韩欧美在线图片| 一区二区三区成人| 亚洲国产一区二区三区青草影视| 欧美三级中文字幕在线观看| 欧美日韩直播| 蜜臀91精品一区二区三区| 欧美精品一区二区三区很污很色的| 性视频1819p久久| 欧美.com| 欧美~级网站不卡| 国产三区精品| 亚洲免费一在线| 日韩一区二区精品视频| 久热精品视频在线免费观看| 亚洲欧美大片| 国产精品99一区二区| 亚洲日本免费| av72成人在线| 欧美日韩精品欧美日韩精品| 欧美日韩一区国产| 99re视频这里只有精品| 日韩亚洲欧美在线观看| 欧美视频你懂的| 日韩亚洲欧美一区| 亚洲欧美怡红院| 国产精品久在线观看| 羞羞色国产精品| 久久久久久色| 亚洲肉体裸体xxxx137| 久久这里有精品15一区二区三区 | 欧美一级片久久久久久久| 欧美国产高清| 一区二区三区精品| 欧美一级免费视频| 精品不卡在线| 亚洲欧美亚洲| 影音先锋久久| 国产精品亚洲人在线观看| 欧美在线看片| 日韩视频在线免费| 久久夜色精品国产欧美乱| 亚洲国产另类 国产精品国产免费| 欧美日韩国产色视频| 欧美一区二区在线视频| 亚洲精品综合在线| 久久夜色精品国产噜噜av| 一区二区三区精品视频在线观看| 国产欧美午夜| 国产精品久久久久久久电影| 免费成人av| 久久在线免费| 久久久美女艺术照精彩视频福利播放 | 久久久国产一区二区三区| 亚洲精品在线三区| 亚洲激情在线播放| 亚洲成色777777女色窝| 久久男人资源视频| 久久av资源网| 免费久久99精品国产自| 欧美mv日韩mv国产网站app| 欧美有码在线观看视频| 亚洲欧美www| 久久久久久一区| 美女91精品| 欧美日韩成人免费| 欧美三级视频在线观看| 欧美天堂亚洲电影院在线观看| 欧美日韩中文字幕在线| 亚洲另类自拍| 亚洲一区二区免费在线| 欧美亚洲自偷自偷| 老色鬼久久亚洲一区二区| 欧美日韩成人激情| 国产日韩一区欧美| 亚洲欧洲在线看| 久久久777| 国产精品福利网| 尤物yw午夜国产精品视频| 亚洲视频精品| 欧美激情一区二区三区蜜桃视频 | 亚洲精品小视频在线观看| 亚洲制服丝袜在线| 欧美精品九九99久久| 激情欧美日韩一区| 欧美一区二区三区视频免费| 欧美日韩黄视频| 亚洲国产精品第一区二区| 欧美中文在线免费| 夜夜嗨av色综合久久久综合网| 久色婷婷小香蕉久久| 国产一区三区三区| 亚洲综合欧美| 一本大道久久a久久精品综合| 猛干欧美女孩| 亚洲人成免费| 美女视频黄免费的久久| 香港久久久电影| 国产视频亚洲| 久久免费一区| 久久人人爽爽爽人久久久| 国内精品国产成人| 久久永久免费| 欧美黄网免费在线观看| 亚洲激情在线观看| 91久久精品国产91性色tv| 欧美国产日产韩国视频| 欧美日韩免费观看一区=区三区| 亚洲麻豆国产自偷在线| 亚洲每日更新| 国产一区 二区 三区一级| 久久亚洲不卡| 欧美日本成人| 欧美影院在线| 欧美久久影院| 久久久久久久久岛国免费| 欧美日韩大陆在线| 欧美日韩一区二区在线视频| 午夜精品久久久久久久蜜桃app| 亚洲欧美日韩国产中文| 亚洲精品小视频在线观看| 中文在线一区| 亚洲精品一区二区三区不| 亚洲午夜激情免费视频| 一本色道久久99精品综合| 欧美在线观看天堂一区二区三区| 日韩西西人体444www| 久久欧美中文字幕| 久久精品二区亚洲w码| 国产精品伊人日日| 一区二区三区四区五区精品视频 | 国产欧美成人| 亚洲精品中文字幕在线观看| 亚洲二区在线观看| 久久久国际精品| 久久色中文字幕| 国产亚洲一级| 欧美一区二区三区免费视频| 久久成人av少妇免费| 国产精品久久久久久影视| 亚洲一区视频| 久久精品视频导航| 合欧美一区二区三区| 久久久久**毛片大全| 欧美成人免费一级人片100| 亚洲国产精品久久久久秋霞影院| 久久综合九色综合久99| 欧美电影在线观看| 99成人精品|