2019/8/7
天气:晴
今天依然很热 大概要到9月中可能才会没这么热吧 今天七夕 愿天下有情人终成眷属
1.GetTickCount
GetTickCount是一种函数。GetTickCount返回(retrieve)从操作系统启动所经过(elapsed)的毫秒数,它的返回值是DWORD。
示例代码
void f_tese1()
{
long t1 = GetTickCount(); //开始时间
for (int i = 0; i < 1000000; i++)
{
int s = 0;
}
long t2 = GetTickCount(); //结束时间
cout << "程序执行时间:" << t2 - t1 << endl; //程序运行的时间得到的时间单位为毫秒 /1000为秒
}
2.C++中的计时函数–clock()
在MSDN中,查得对clock函数定义如下: clock_t clock( void ); 这个函数返回从“开启这个程序进程”到“程序中调用clock()函数”时之间的CPU时钟计时单元(clock tick)数,在MSDN中称之为挂钟时间(wal-clock)。其中clock_t是用来保存时间的数据类型,在time.h文件中,我们可以找到对它的定义:
#ifndef _CLOCK_T_DEFINED
typedef long clock_t;
#define _CLOCK_T_DEFINED
#endif
很明显,clock_t是一个长整形数。在time.h文件中,还定义了一个常量CLOCKS_PER_SEC,它用来表示一秒钟会有多少个时钟计时单元,其定义如下:
#define CLOCKS_PER_SEC ((clock_t)1000) 可以看到每过千分之一秒(1毫秒),调用clock()函数返回的值就加1。
示例代码
void f_test2()
{
clock_t start, finish;
start = clock();
for (int i = 0; i < 1000000; i++)
{
int s = 0;
}
finish = clock();
cout << "程序执行时间:" << (double)(finish - start) << endl;
}
3.高精度时控函数QueryPerformanceFrequency(),QueryPerformanceCounter()
原理:QueryPerformanceCounter()这个函数返回高精确度性能计数器的值,它可以以微妙为单位计时.但是QueryPerformanceCounter()确切的精确计时的最小单位是与系统有关的,所以,必须要查询系统以得到QueryPerformanceCounter()返回的嘀哒声的频率.QueryPerformanceFrequency()提供了这个频率值,返回每秒嘀哒声的个数. 计算确切的时间是从第一次调用QueryPerformanceCounter()开始的假设得到的LARGE_INTEGER为nStartCounter,过一段时间后再次调用该函数结束的,设得到nStopCounter.两者之差除以QueryPerformanceFrequency()的频率就是开始到结束之间的秒数.由于计时函数本身要耗费很少的时间,要减去一个很少的时间开销.但一般都把这个开销忽略。
头文件:
#include<windows.h>
示例代码
void f_test3()
{
double time = 0;
double counts = 0;
LARGE_INTEGER nFreq;
LARGE_INTEGER nBeginTime;
LARGE_INTEGER nEndTime;
QueryPerformanceFrequency(&nFreq);
QueryPerformanceCounter(&nBeginTime);//开始计时
for (int i = 0; i < 1000000; i++)
{
int s = 0;
}
QueryPerformanceCounter(&nEndTime);//停止计时
time = (double)(nEndTime.QuadPart - nBeginTime.QuadPart) / (double)nFreq.QuadPart;//计算程序执行时间单位为s
cout << "运行时间:" << time * 1000 << "ms" << endl;
}
4.使用Boost库中的timer
timer类可以测量时间的流逝,是小型计时器,提供毫秒级别的计时精度。
头文件:
#include<boost/timer.hpp>
示例代码
timer t;//声明计时器对象并开始计时
//...测试代码
cout<<"运行时间:"<<t.elapsed() <<"s"<<endl;//输出已流失的时间