C++中几种测试程序运行时间的方法
来源:互联网 发布:java实训基地 编辑:程序博客网 时间:2024/06/05 06:35
一、使用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;}
#include<boost/timer.hpp>#include<iostream>using namespace std;using namespace boost;int main(){ timer t;//声明计时器对象并开始计时
Sleep(500);//需要测试的运行代码 cout<<"now:"<<t.elapsed() <<"s"<<endl;//输出已流失的时间}
- 【C++】C++中几种测试程序运行时间的方法
- 测试程序运行时间的方法
- C#程序运行时间的测试方法
- C++中几种测试程序运行时间的方法
- 测试C程序运行时间
- 测试用C/C++编写的程序运行的时间
- 测试程序运行的时间
- 测试程序的运行时间
- 测试程序的运行时间
- C#Stopwatch可以精准的测试程序运行时间
- 测试程序运行时间的三种方法
- WinCE下测试程序运行时间的方法
- 测试某一段程序运行时间的方法
- C语言中测试程序运行时间
- C语言中测试程序运行时间
- C/C++ 测试程序运行时间
- c/c++测试程序运行时间
- C语言中测试程序运行时间
- js获取当前页面的URL信息
- Bootstrap响应式图片的进一步处理
- Caffe安装教程
- Ionic消息提示插件
- C++虚析构函数 http://c.biancheng.net/cpp/biancheng/view/247.html
- C++中几种测试程序运行时间的方法
- 将导航栏的二级菜单的back按钮替换
- 控制反转与依赖注入
- OutOfMemory Java heap space解决方法
- 安卓平台多个视频叠加演示demo说明
- shell脚本学习2
- 数据结构之插入排序
- 关于Android 设置监听的的四种方式的理解
- 【数据压缩】LZW算法原理与源码解析