测试1秒钟休眠所耗费的时间

 //Timer1.cpp 使用了RDTSC指令的Timer类//KTimer类的定义可以参见《Windows图形编程》P15

//编译行:CL Timer1.cpp /link USER32.lib

#include <stdio.h>

#include "KTimer.h"

main()

{

unsigned t;

KTimer timer;

timer.Start();

Sleep(1000);

t = timer.Stop();

printf("Lasting Time: %dn",t);

}



//Timer2.cpp 使用了timeGetTime函数

//需包含<mmsys.h>,但由于Windows头文件错综复杂的关系

//简单包含<windows.h>比较偷懒:)

//编译行:CL timer2.cpp /link winmm.lib

#include <windows.h>

#include <stdio.h>



main()

{

DWORD t1, t2;

t1 = timeGetTime();

Sleep(1000);

t2 = timeGetTime();

printf("Begin Time: %un", t1);

printf("End Time: %un", t2);

printf("Lasting Time: %un",(t2-t1));

}



//Timer3.cpp 使用了QueryPerformanceCounter函数

//编译行:CL timer3.cpp /link KERNEl32.lib

#include <windows.h>

#include <stdio.h>



main()

{

LARGE_INTEGER t1, t2, tc;

QueryPerformanceFrequency(&tc);

printf("Frequency: %un", tc.QuadPart);

QueryPerformanceCounter(&t1);

Sleep(1000);

QueryPerformanceCounter(&t2);

printf("Begin Time: %un", t1.QuadPart);

printf("End Time: %un", t2.QuadPart);

printf("Lasting Time: %un",( t2.QuadPart- t1.QuadPart));

}



////////////////////////////////////////////////

//以上三个示例程序都是测试1秒钟休眠所耗费的时间

file://测/试环境:Celeron 800MHz / 256M SDRAM

// Windows 2000 Professional SP2

// Microsoft Visual C++ 6.0 SP5

////////////////////////////////////////////////



以下是Timer1的运行结果,使用的是高精度的RDTSC指令

Lasting Time: 804586872



以下是Timer2的运行结果,使用的是最粗糙的timeGetTime API

Begin Time: 20254254

End Time: 20255255

Lasting Time: 1001



以下是Timer3的运行结果,使用的是QueryPerformanceCount API

Frequency: 3579545

Begin Time: 3804729124

End Time: 3808298836

Lasting Time: 3569712

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值