设为首页 加入收藏

TOP

C++计时的几种方法说明及例程
2014-11-24 00:14:56 来源: 作者: 【 】 浏览:4
Tags:++计时 方法 说明

1. 使用clock() 函数

头文件:

clock()函数,返回“自程序启动到调用该函数,CPU时钟的计时单元数(clock tick)”

每过1ms,计数值+1


精度:1毫秒


#include
#include

int main()
{
clock_t start,end; // typedef long clock_t
start = clock();
long i= 1000000000L;while(i--){}
end = clock();

//#define CLOCKS_PER_SEC ((clock_t)1000)
double duration =(double)(end-start)/CLOCKS_PER_SEC;
printf("%f\n",duration); // 4.015

return 0;
}


2. 使用time() 函数

头文件:

clock()返回公元1970.01.01 0:0:0秒算起到现在所经过的秒数。

即Calendar Time,日历时间

精度:1秒


#include

int main()
{
time_t start,end; // typedef long time_t;
start = time(NULL); // 等同于 time(&start);
long i=1000000000L;while(i--){}
end = time(NULL);

long duration =end - start;
printf("%ld\n",duration); // 4

return 0;
}


3. 使用GetTickCount () 函数


头文件:


在精度要求较高的情况下,可以利用GetTickCount()函数,该函数的返回值是 DWORD型,表示以ms为单位的计算机启动后经历的时间间隔(最大49.7天)。在较短的定时中其计时误差为15ms,在较长的定时中其计时误差较低,如果定时时间太长,就好象死机一样,CPU占用率非常高,只能用于要求不高的延时程序中。


精度:1毫秒,短时误差15ms


#include
#include

int main()
{
DWORD start,end;//typedef unsigned long DWORD;
start = GetTickCount();
long i=1000000000L;while(i--){}
end = GetTickCount();

double duration = (double)(end-start)/1000;
printf("%f\n",duration); // 3.922
return 0;
}


4. 使用QueryFrequencyCount () 函数


头文件:


高精度计数器


精度:1微秒,误差不超过0.5微妙(精度为1000 000/(cpu主频)微秒)


#include
#include

int main()
{
LARGE_INTEGER f;
QueryPerformanceFrequency(&f);//获取内部高精度计数器的频率

double dFreq;
dFreq = (double)f.QuadPart; //获取计数器的频率

LARGE_INTEGER start,end;
QueryPerformanceCounter(&start);//获取内部高精度计数器当前的计数值
long i=1000000000L;while(i--){}
QueryPerformanceCounter(&end);

//时间差 = 计数值差/频率(单位s)
double duration = (double)(end.QuadPart-start.QuadPart)/dFreq;
printf("%f\n",duration);// 3.969499
return 0;
}


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇在64位Ubuntu下面使用Android NDK.. 下一篇Linux正则表达式特性及BRE与ERE的..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: