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

C++ Programmer's Cookbook

{C++ 基礎} {C++ 高級} {C#界面,C++核心算法} {設計模式} {C#基礎}

使用API實現1/1000秒的性能測試類

?

// ?MbUnit?Test?Framework
// ?
// ?Copyright?(c)?2004?Jonathan?de?Halleux
//
// ?This?software?is?provided?'as-is',?without?any?express?or?implied?warranty.?
// ?
// ?In?no?event?will?the?authors?be?held?liable?for?any?damages?arising?from?
// ?the?use?of?this?software.
// ?Permission?is?granted?to?anyone?to?use?this?software?for?any?purpose,?
// ?including?commercial?applications,?and?to?alter?it?and?redistribute?it?
// ?freely,?subject?to?the?following?restrictions:
//
// ????????1.?The?origin?of?this?software?must?not?be?misrepresented;?
// ????????you?must?not?claim?that?you?wrote?the?original?software.?
// ????????If?you?use?this?software?in?a?product,?an?acknowledgment?in?the?product?
// ????????documentation?would?be?appreciated?but?is?not?required.
//
// ????????2.?Altered?source?versions?must?be?plainly?marked?as?such,?and?must?
// ????????not?be?misrepresented?as?being?the?original?software.
//
// ????????3.?This?notice?may?not?be?removed?or?altered?from?any?source?
// ????????distribution.
// ????????
// ????????MbUnit?HomePage:? http://mbunit.tigris.org
// ????????Author:?Jonathan?de?Halleux

using ?System;
using ?System.Runtime.InteropServices;
using ?System.ComponentModel;
using ?System.Threading;

namespace ?MbUnit.Core.Monitoring
{
????
/// ? <summary>
????
/// ?A?high?performance?timer
????
/// ? </summary>
????
/// ? <remarks>
????
/// ?High?Precision?Timer?based?on?Win32?methods.
????
/// ? </remarks>
????
/// ? <example>
????
/// ?This?example?times?the?execution?of?a?method:
????
/// ? <code>
????
/// ?TimeMonitor?timer?=?new?TimeMonitor();
????
/// ?timer.Start();
????
/// ?????//?execute?code
????
/// ?timer.Stop();
????
/// ?
????
/// ?Console.WriteLine("Duration:?{0}",timer.Duration);
????
/// ? </example>

???? public ? class ?TimeMonitor
????
{
????????[DllImport(
" Kernel32.dll " )]
????????
private ? static ? extern ? bool ?QueryPerformanceCounter( out ? long ?lpPerformanceCount);??

????????[DllImport(
" Kernel32.dll " )]
????????
private ? static ? extern ? bool ?QueryPerformanceFrequency( out ? long ?lpFrequency);
????????
????????
private ? long ?startTime,?stopTime;
????????
private ? long ?now;
????????
private ? long ?freq;
????????
????????
/// ? <summary> Default?constructor </summary>
????????
/// ? <remarks> Initializes?the?timer. </remarks>

???????? public ?TimeMonitor()
????????
{
????????????startTime?
= ? 0 ;
????????????stopTime??
= ? 0 ;

????????????
if ?(QueryPerformanceFrequency( out ?freq)? == ? false )
????????????
{
????????????????
// ?high-performance?counter?not?supported?
???????????????? throw ? new ?Win32Exception();?
????????????}

????????}

????????
????????
/// ? <summary> Gets?the?clock?frequency </summary>
????????
/// ? <value> Clock?frequency </value>

???????? public ? long ?Frequency
????????
{
????????????
get
????????????
{
????????????????
return ? this .freq;
????????????}

????????}

????????
????????
/// ? <summary> Starts?the?timer </summary>
????????
/// ? <remarks> Resets?the?duration?and?starts?the?timer </remarks>

???????? public ? void ?Start()
????????
{
????????????
// ?lets?do?the?waiting?threads?there?work
????????????Thread.Sleep( 0 );??

????????????QueryPerformanceCounter(
out ?startTime);
????????}

????????
????????
/// ? <summary> Stops?the?timer </summary>
????????
/// ? <remarks> Stops?the?timer </remarks>

???????? public ? void ?Stop()
????????
{
????????????QueryPerformanceCounter(
out ?stopTime);
????????}

????????
????????
/// ? <summary> Gets?the?current?duration?value?without?stopping?the?timer </summary>
????????
/// ? <value> Current?duration?value </value>

???????? public ? double ?Now
????????
{
????????????
get
????????????
{
????????????????QueryPerformanceCounter(
out ?now);
????????????????
return ?( double )(now? - ?startTime)? / ?( double )?freq;
????????????}
????????
????????}


????????
/// ? <summary> Gets?the?timed?duration?value?in?seconds </summary>
????????
/// ? <value> Timer?duration </value>

???????? public ? double ?Duration
????????
{
????????????
get
????????????
{
????????????????
return ?( double )(stopTime? - ?startTime)? / ?( double )?freq;
????????????}

????????}

????}

}




c++版的:
High-resolution?timer?for?timing?code?fragments?


Timing?of?code?fragments?
is?simple:?

record?the?start?time?
execute?the?code?
record?the?end?time?
calucate?the?difference?between?end?and?start?
For?timing?exuction?time?of?pieces?of?code?you?need?a?high
-resolution?timer.?On?Windows,?Windows?CE?and?Pocket?PC/Smartphone?(which?are?Windows?CE?variations)?you?can?use?QueryPerformanceCounter?and?QueryPerformanceFrequence?API?calls.?

Here
's?a?simple?implementation?in?C:?

typedef?
struct?prof_timer_t?{
????LARGE_INTEGER?time_start;
????LARGE_INTEGER?time_stop;
}
?prof_timer_t;

void?prof_timer_start(prof_timer_t?*timer)?{
????QueryPerformanceCounter(
&timer->time_start);
}


void?prof_timer_stop(prof_timer_t?*timer)?{
????QueryPerformanceCounter(
&timer->time_stop);
}


double?prof_timer_get_duration_in_secs(prof_timer_t?*timer)?{
????LARGE_INTEGER?freq;
????
double?duration;
????QueryPerformanceFrequency(
&freq);
????duration?
=?(double)(timer->time_stop.QuadPart-timer->time_start.QuadPart)/(double)freq.QuadPart;
????
return?duration;
}


And?
in?C++:?

//?very?simple,?high-precision?(at?least?in?theory)?timer?for?timing?API?calls
struct?ProfTimer?{
????
void?Start(void)?{
????????QueryPerformanceCounter(
&mTimeStart);
????}
;
????
void?Stop(void)?{
????????QueryPerformanceCounter(
&mTimeStop);
????}
;
????
double?GetDurationInSecs(void)
????
{
????????LARGE_INTEGER?freq;
????????QueryPerformanceFrequency(
&freq);
????????
double?duration?=?(double)(mTimeStop.QuadPart-mTimeStart.QuadPart)/(double)freq.QuadPart;
????????
return?duration;
????}


????LARGE_INTEGER?mTimeStart;
????LARGE_INTEGER?mTimeStop;
}
;

And?here
's?an?example?of?using?the?C++?version:?

????ProfTimer?t;
????t.Start();
????foo();
????t.Stop();
????
double?dur?=?t.GetDurationInSecs();
????printf(
"executing?foo()?took?%f?seconds\n"?,?dur);

posted on 2006-06-16 14:07 夢在天涯 閱讀(1739) 評論(1)  編輯 收藏 引用 所屬分類: CPlusPlus 、C#/.NET 、VS2005/2008

評論

# re: 性能測試類 2006-06-16 14:26 夢在天涯

GetTickCount()和GetCurrentTime()都只精確到55ms(1個tick就是55ms)。如果要精確到毫秒,應該使用timeGetTime函數或QueryPerformanceCounter函數。
雖然timeGetTime返回值的單位是1ms,但實際上它的精度只有10ms左右。
如果想提高精度,可以使用QueryPerformanceCounter和QueryPerformanceFrequency。這兩個函數不是在每個系統中都支持。對于支持它們的系統中,可以獲得低于1ms的精度。Windows 內部有一個精度非常高的定時器, 精度在微秒級, 但不同的系統這個定時器的頻率不同, 這個頻率與硬件和操作系統都可能有關。利用 API 函數 QueryPerformanceFrequency 可以得到這個定時器的頻率。利用 API 函數 QueryPerformanceCounter 可以得到定時器的當前值。根據要延時的時間和定時器的頻率, 可以算出要延時的時間定時器經過的周期數。在循環里用 QueryPerformanceCounter 不停的讀出定時器值, 一直到經過了指定周期數再結束循環, 就達到了高精度延時的目的。  回復  更多評論   

公告

EMail:itech001#126.com

導航

統計

  • 隨筆 - 461
  • 文章 - 4
  • 評論 - 746
  • 引用 - 0

常用鏈接

隨筆分類

隨筆檔案

收藏夾

Blogs

c#(csharp)

C++(cpp)

Enlish

Forums(bbs)

My self

Often go

Useful Webs

Xml/Uml/html

搜索

  •  

積分與排名

  • 積分 - 1815003
  • 排名 - 5

最新評論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
              国产精品大全| 久久精品一区二区三区四区| 国产精品高潮在线| 久热综合在线亚洲精品| 久久亚洲高清| 亚洲第一黄色| 亚洲欧洲日产国码二区| 91久久国产精品91久久性色| 亚洲精品久久久久久下一站 | 欧美激情亚洲国产| 欧美日韩久久精品| 国产精品视频久久久| 国产亚洲福利| 亚洲精品视频一区二区三区| 午夜精品一区二区三区电影天堂| 久久精品国产第一区二区三区最新章节| 久久精品国产免费看久久精品| 另类图片国产| 亚洲精选大片| 久久久久久一区二区| 欧美色中文字幕| 亚洲国产成人久久综合一区| 亚洲天堂久久| 久久亚洲图片| 一区二区三区 在线观看视| 欧美自拍偷拍| 欧美激情久久久久久| 亚洲色图在线视频| 麻豆国产精品777777在线| 欧美日韩国产专区| 伊人久久噜噜噜躁狠狠躁| 一区二区欧美激情| 欧美 日韩 国产一区二区在线视频| 欲香欲色天天天综合和网| 日韩午夜在线| 免费观看日韩| 久久精品视频在线看| 欧美日韩亚洲一区二区三区在线观看 | 亚洲第一主播视频| 亚洲免费一区二区| 亚洲第一中文字幕| 久久久精品国产免费观看同学| 国产精品av一区二区| 亚洲国产日韩一级| 欧美一区二区观看视频| 99天天综合性| 欧美人与性动交cc0o| 亚洲国产精品一区制服丝袜| 久久高清一区| 亚洲欧美怡红院| 国产精品美女主播在线观看纯欲| 日韩亚洲国产精品| 亚洲高清久久网| 美女任你摸久久| 在线观看91久久久久久| 久久福利资源站| 亚洲女与黑人做爰| 国产精品国产馆在线真实露脸| av成人国产| 亚洲精品乱码久久久久久蜜桃麻豆| 久久精品欧洲| 伊人成人开心激情综合网| 久久婷婷蜜乳一本欲蜜臀| 欧美在线免费| 韩国精品一区二区三区| 久久久亚洲综合| 久久乐国产精品| 亚洲国产精品久久久久婷婷老年| 免费在线观看精品| 欧美 日韩 国产 一区| 亚洲韩国精品一区| 亚洲国产免费看| 欧美激情第六页| 亚洲一区二区三区四区视频| 中文精品视频| 国产区亚洲区欧美区| 久久精品国产亚洲精品| 久久精品国产视频| 欧美sm视频| 日韩午夜在线电影| 亚洲一区二区网站| 在线成人激情黄色| 99热精品在线| 国产主播精品| 亚洲日本黄色| 国产欧美精品在线观看| 欧美 日韩 国产 一区| 欧美日韩国产麻豆| 欧美一区影院| 你懂的国产精品| 亚洲欧美日本国产专区一区| 久久国产综合精品| 亚洲免费观看视频| 欧美一区二区三区在线看| 最新精品在线| 香蕉国产精品偷在线观看不卡| 最新国产成人av网站网址麻豆| 亚洲视频一二三| 在线播放日韩欧美| 一区二区三区蜜桃网| 亚洲高清在线观看| 亚洲欧美成人精品| 夜夜嗨av一区二区三区四区| 欧美综合国产| 亚洲自拍偷拍视频| 欧美大片在线观看一区二区| 久久精品人人做人人综合| 欧美日韩一视频区二区| 欧美 日韩 国产一区二区在线视频| 国产精品美女在线观看| 亚洲精品在线观看视频| 在线观看av不卡| 午夜激情综合网| 一区二区日韩伦理片| 久久久水蜜桃| 久久久999精品免费| 国产精品毛片在线| 亚洲日本中文字幕区| 亚洲国产精品电影在线观看| 亚洲欧美经典视频| 亚洲欧美日韩系列| 欧美午夜宅男影院| 亚洲美女黄网| 亚洲精品麻豆| 免费视频一区| 欧美成人精品在线视频| 黄色一区二区三区| 久久国产加勒比精品无码| 性伦欧美刺激片在线观看| 欧美三级视频在线播放| 99视频精品在线| 亚洲一二三区在线观看| 欧美精品久久99| 亚洲片区在线| 一本不卡影院| 欧美三级欧美一级| 99在线精品观看| 亚洲一区二区三区高清| 欧美日韩中文精品| 一区二区三区视频观看| 亚洲免费在线视频| 国产精品天美传媒入口| 午夜亚洲性色视频| 蜜桃精品久久久久久久免费影院| 一区在线观看| 欧美成人国产| 一区二区日韩精品| 欧美日韩在线精品| 一区二区福利| 欧美伊人久久| 影音先锋中文字幕一区| 麻豆久久婷婷| 日韩一级黄色片| 久久超碰97人人做人人爱| 黑人巨大精品欧美一区二区小视频| 久久久91精品国产| 亚洲电影免费观看高清完整版| 日韩视频三区| 国产欧美综合一区二区三区| 久久久久久亚洲精品杨幂换脸| 亚洲国产高清一区二区三区| 国产精品99久久久久久www| 国产精品五月天| 久久全国免费视频| 一本色道久久88亚洲综合88| 久久久久88色偷偷免费| 亚洲精品欧美一区二区三区| 欧美日韩二区三区| 欧美一二三视频| 亚洲国内自拍| 久久成人精品无人区| 最近中文字幕日韩精品| 国产精品亚洲аv天堂网 | 欧美体内谢she精2性欧美| 午夜天堂精品久久久久| 亚洲黄色视屏| 久久久噜噜噜久噜久久 | 久久久久国产成人精品亚洲午夜| 欧美激情一级片一区二区| 亚洲欧美日韩另类精品一区二区三区| 1204国产成人精品视频| 国产精品视频99| 欧美精品在线极品| 久久精品国产999大香线蕉| 一区二区三区日韩在线观看| 亚洲国产精品传媒在线观看| 欧美诱惑福利视频| 亚洲视频一区二区免费在线观看| 激情欧美丁香| 国产欧美精品久久| 欧美午夜大胆人体| 欧美国产在线视频| 久久久久久久久综合| 亚洲男人av电影| 亚洲麻豆av| 亚洲欧洲在线一区| 欧美激情一区二区三区高清视频 | 欧美日韩亚洲国产一区| 蜜桃av一区二区在线观看| 欧美在线网站|