C++中几种测试程序运行时间的方法

一、使用GetTickCount()函数

   原理:GetTickCount()是获取系统启动后的时间间隔。通过进入函数开始定时,到退出函数结束定时,从而可以判断出函数的执行时间,这种时间也并非是函数或者算法的真实执行时间,因为在函数和算法线程不可能一直占用CPU,对于所有判断执行时间的函数都是一样,不过基本上已经很准确,可以通过查询进行定时。注意:GetTickCount()精确度有限,跟CPU有关,一般精确度在16ms左右,最精确也不会精确过10ms。

使用方法:

#include<windows.h>
#include<iostream>
using namespace std;
int main()
{
    <span style="white-space:pre">	</span>long t1 = GetTickCount();
<span style="white-space:pre">	</span>Sleep(500);//此处可换为自己想要测试的代码
<span style="white-space:pre">	</span>long t2 = GetTickCount();
<span style="white-space:pre">	</span>//精度测试
<span style="white-space:pre">	</span>long t3 = GetTickCount();
<span style="white-space:pre">	</span>Sleep(10);
<span style="white-space:pre">	</span>long t4 = GetTickCount();


<span style="white-space:pre">	</span>long t5 = GetTickCount();
<span style="white-space:pre">	</span>Sleep(5);
<span style="white-space:pre">	</span>long t6 = GetTickCount();
<span style="white-space:pre">	</span>cout<<"测试Sleep(500)运行时间为:"<<t2-t1<<"ms"<<endl;
<span style="white-space:pre">	</span>cout<<"-------------------------------"<<endl;
<span style="white-space:pre">	</span>cout<<"测试Sleep(10)运行时间为:"<<t4-t3<<"ms"<<"(此处结果因精度不够造成)"<<endl;
<span style="white-space:pre">	</span>cout<<"-------------------------------"<<endl;
<span style="white-space:pre">	</span>cout<<"测试Sleep(5)运行时间为:"<<t6-t5<<"ms"<<"(此处结果因精度不够造成)"<<endl;


}<span style="color:#ff0000;">
</span>
运行结果:

二、高精度时控函数QueryPerformanceFrequency(),QueryPerformanceCounter()

原理:

QueryPerformanceCounter()这个函数返回高精确度性能计数器的值,它可以以微妙为单位计时.但是QueryPerformanceCounter()确切的精确计时的最小单位是与系统有关的,所以,必须要查询系统以得到QueryPerformanceCounter()返回的嘀哒声的频率.

QueryPerformanceFrequency()提供了这个频率值,返回每秒嘀哒声的个数.

计算确切的时间是从第一次调用QueryPerformanceCounter()开始的

假设得到的LARGE_INTEGER为nStartCounter,过一段时间后再次调用该函数结束的,

设得到nStopCounter.

两者之差除以QueryPerformanceFrequency()的频率就是开始到结束之间的秒数.由于计时函数本身要耗费很少的时间,要减去一个很少的时间开销.但一般都把这个开销忽略。

使用方法:

#include<windows.h>
#include<iostream>
using namespace std;
int main()
{
        double time=0;
        double counts=0;
        LARGE_INTEGER nFreq;
	LARGE_INTEGER nBeginTime;
	LARGE_INTEGER nEndTime;
	QueryPerformanceFrequency(&nFreq);
        QueryPerformanceCounter(&nBeginTime);//开始计时
	    for(int i=0;i<99999;i++)
        {
            counts++;
        }
        QueryPerformanceCounter(&nEndTime);//停止计时
        time=(double)(nEndTime.QuadPart-nBeginTime.QuadPart)/(double)nFreq.QuadPart;//计算程序执行时间单位为s
        cout<<"程序执行时间:"<<time*1000<<"ms"<<endl;
}




三、使用Boost库中的timer

    timer类可以测量时间的流逝,是小型计时器,提供毫秒级别的计时精度。

使用方法:

#include<boost/timer.hpp>
#include<iostream>
using namespace std;
using namespace boost;
int main()
{
    timer t;//声明计时器对象并开始计时
     Sleep(500);//需要测试的运行代码
    cout<<"now:"<<t.elapsed() <<"s"<<endl;//输出已流失的时间
}


  • 4
    点赞
  • 40
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值