加入收藏 | 设为首页 | 会员中心 | 我要投稿 济南站长网 (https://www.0531zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 教程 > 正文

C++计时的几种措施说明及例程

发布时间:2021-11-20 16:59:44 所属栏目:教程 来源:互联网
导读:1. 使用clock() 函数 头文件:time.h clock()函数,返回自程序启动到调用该函数,CPU时钟的计时单元数(clock tick) 每过1ms,计数值+1 精度:1毫秒 #include stdio.h #include time.h int main() { clock_t start,end; // typedef long clock_t start = cl

1. 使用clock() 函数                                               
 
头文件:<time.h>
 
clock()函数,返回“自程序启动到调用该函数,CPU时钟的计时单元数(clock tick)”
 
每过1ms,计数值+1
 
精度:1毫秒
 
#include <stdio.h>
#include <time.h>
 
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("%fn",duration); // 4.015
 
    return 0;
}
 
2. 使用time() 函数                                                 
 
头文件:<time.h> 中
 
clock()返回公元1970.01.01 0:0:0秒算起到现在所经过的秒数。
 
即Calendar Time,日历时间
 
精度:1秒
 
#include <time.h>
 
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("%ldn",duration); // 4
 
    return 0;
}
 
3. 使用GetTickCount () 函数
 
头文件:<windows.h> 中
 
在精度要求较高的情况下,可以利用GetTickCount()函数,该函数的返回值是  DWORD型,表示以ms为单位的计算机启动后经历的时间间隔(最大49.7天)。在较短的定时中其计时误差为15ms,在较长的定时中其计时误差较低,如果定时时间太长,就好象死机一样,CPU占用率非常高,只能用于要求不高的延时程序中。
 
精度:1毫秒,短时误差15ms
 
#include <stdio.h>
#include <windows.h>
 
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("%fn",duration); // 3.922
    return 0;
}
 
4. 使用QueryFrequencyCount () 函数
 
头文件:<windows.h>
 
高精度计数器
 
精度:1微秒,误差不超过0.5微妙(精度为1000 000/(cpu主频)微秒)
 
#include <stdio.h>
#include <windows.h>
 
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("%fn",duration);// 3.969499
    return 0;
}

(编辑:济南站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读