linux下程序计时方法

最近简单学习了下 Linux 下 C++ 程序计时的一些函数和方法,总结如下。没啥 insight 了。

方法一:

如果是想统计某个程序的运行时间,那么可以使用

time ./a.out

方法二:

如果是想对某个函数或者语句进行计时,那么有别的方法。比如说, gettimeofday 函数。直接贴示例代码:

#include <sys/time.h>
void f()
{
  //...
}
int main()
{
  struct timeval t1, t2;
  gettimeofday(&t1, NULL);
  f();
  gettimeofday(&t2, NULL);
  //那么函数f运行所花的时间为
  //deltaT = (t2.tv_sec-t1.tv_sec) * 1000000 + t2.tv_usec-t1.tv_usec 微秒
  return 0;
}

不难看出, gettimeofday 只能精确到微秒;如果想精确到纳秒呢?

方法三:

#include <time.h>
void f()
{
  //...
}
int main()
{
  timespec t1, t2;
  clock_gettime(CLOCK_MONOTONIC, &t1);
  f();
  clock_gettime(CLOCK_MONOTONIC, &t2);
  //那么f所花时间为
  //deltaT = (t2.tv_sec - t1.tv_sec) * 10^9 + t2.tv_nsec - t1.tv_nsec 纳秒
  return 0;
}

这里说的都是 wall clock ,如果想获得 cpu 执行时间,以及了解 clock_gettime 参数的解释和可能的取值,可以 man 一下。

转自: http://www.yebangyu.org/blog/2016/01/07/timingcprograminlinux/


另:

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("%f\n",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("%ld\n",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("%f\n",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("%f\n",duration);// 3.969499
    return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值