织梦CMS - 轻松建站从此开始!

罗索

Linux 时间计量与日历时间转换(附代码)

落鹤生 发布于 2012-01-14 16:49 点击:次 
运行第二段中的demo可以大体判断timeval来计时相对来说准确一点。这里只是介绍 Linux 平台下 c 语言中计算程序运行时间的方法, 它们各有利弊,依据自己的需要可以使用对应的方法。
TAG:

(一) Linux 的 时间概念

       Linux 系统下统计程序运行实践最简单直接的方法就是使用 time 命令,此命令的用途在于测量特定指令执行时所需消耗的时间及系统资源等资讯,在统计的时间结 果中包含以下数据:

       (1) 实际时间( real time ):从命令行执行到运行终止的消逝时间;

       (2) 用户 CPU 时间( user CPU time ):命 令执行完成花费的系统 CPU 时间,即命令在用户态中执行时间的总和;

       (3) 系统 CPU 时间( system CPU time ): 命令执行完成花费的系统 CPU 时间,即命令在核心态中执行时间的总和。

       其中,用户 CPU 时 间和系统 CPU 时间之和为 CPU 时 间,即命令占用 CPU 执行的时间总和。实际时间要大于 CPU时 间,因为 Linux 是多任务操作系统,往往在执行一条命令时,系统还要处理其他任务。另一个需要注意的问题是即使每次 执行相同的命令,所花费的时间也不一定相同,因为其花费的时间与系统运行相关。

 

(二)下面直接给出5种变量类型的代码断来进行说明,

clock_t、struct tms相关为计时测领,

time_t、struct tm相关为日历时间测量。

timeval 相当于更精确的time_t,格式为秒数.微秒数

#include <time.h> 
#include <sys/times.h> //需要sys目录 
#include <stdlib.h> 
#include <stdio.h> 
#include <unistd.h> 
#include <fcntl.h> 
 
int main(int argc,char* argv[]) 

   
  long    i = 1000000000L;

clock_t start_c, finish_c; 
  time_t start_t,finish_t; 
  struct timeval start_stv,finish_stv; //对time_t类型的封装 
  struct tms start_stms,finish_stms;//对clock_t类型的封装 
  struct tm *start_stm,*finish_stm; //对time_t进行变体,类型为int 
  double  duration; 
  long luration; 
   
   /* 测量一个事件持续的时间*/ 
  printf( "Time to do %ld empty loops is \n", i ); 
 
  start_c = times(&start_stms); //从后面可以看出times和clock取得的clock_t的数量级不一样,一个为毫秒*10,一个为微妙 
  start_c = clock();//进程时间测量,进程开始时调用时返回为0 
  start_t = time(NULL); //只能精确到秒 
  gettimeofday(&start_stv,NULL); 
 
  start_stm = localtime(&start_t); //时钟向日历时间的转换,mktime为其逆向过程函数,日历的函数有很多,我一般用这个记那么多格式也累,用的时候再man 
 
  //也可以通过ctime直接打印出时间来。 
  printf("====\nstart time:%04d-%02d-%02d %02d:%02d:%02d\n", 
         start_stm->tm_year+1900, 
         start_stm->tm_mon+1, 
         start_stm->tm_mday, 
         start_stm->tm_hour, 
         start_stm->tm_min, 
         start_stm->tm_sec); 
  printf("start time:%s",ctime(&start_t)); 
     
  while( i-- )      ; 
 
  finish_c = times(&finish_stms); 
  finish_c = clock(); 
  finish_t = time(NULL); 
  gettimeofday(&finish_stv,NULL); 
   
  duration = (double)(finish_c - start_c)/CLOCKS_PER_SEC; ; 
  printf( "1. [clock_t] get  %f secondes,start = %u,finish =%u\n",duration,start_c,finish_c ); 
 
  luration = (finish_t - start_t); 
  printf("2. [time_t] get %u seconds,start = %u, finish = %u\n",luration,start_t,finish_t); 
 
  luration = (finish_stv.tv_sec - start_stv.tv_sec)*1000 + ( finish_stv.tv_usec - start_stv.tv_usec)/1000; 
  printf("3. [struct timeval] get %u ms,start=%u,finish=%u\n",luration,start_stv.tv_sec,finish_stv.tv_sec); 
 
  long clktck=sysconf(_SC_CLK_TCK); 
   
  printf("================_SC_CLK_TCK=%d,CLOCKS_PER_SEC=%d\n",clktck,CLOCKS_PER_SEC); 
 
   
  printf("4. [struct tms] get user= %7.2f,sys=%7.2f,child_user=%7.2f,child_sys=%7.2f\n", 
         (finish_stms.tms_utime - start_stms.tms_utime)/(double)clktck, 
         (finish_stms.tms_stime - start_stms.tms_stime)/(double)clktck, 
         (finish_stms.tms_cutime - start_stms.tms_cutime)/(double)clktck, 
         (finish_stms.tms_cstime - start_stms.tms_cstime)/(double)clktck );  

  exit(0);
}

(三) struct结构说明

structtm {

 

  int tm_sec; /* 秒–取值区间为[0,59] */

 

  int tm_min; /* 分 - 取值区间为[0,59] */

 

  int tm_hour; /* 时 - 取值区间为[0,23] */

 

  int tm_mday; /* 一个月中的日期 - 取值区间为[1,31] */

 

  int tm_mon; /* 月份(从一月开始,0代表一月) - 取值区间为[0,11] */

 

  int tm_year; /* 年份,其值从1900开始 */

 

  int tm_wday; /* 星期–取值区间为[0,6],其中0代表星期天,1代表星期一,以此类推 */

 

  int tm_yday; /* 从每年的1月1日开始的天数–取值区间为[0,365],其中0代表1月1日,1代表1月2日,以此类推 */

 

  int tm_isdst; /* 夏令时标识符,实行夏令时的时候,tm_isdst为正。不实行夏令时的进候,tm_isdst为0;不了解情况时,tm_isdst()为负。*/

 

  };

 

struct tms{
         clock_t  tms_utime;   /* user cpu time */
         clock_t  tms_stime;   /* system cpu time */
         clock_t  tms_cutime;  /* user cpu time of children */
         clock_t  tms_cstime;  /* system cpu time of children */
   };

struct timeval {

 

  time_t tv_sec; /* seconds */

 

  suseconds_t tv_usec; /* microseconds */

 

  };

(四)总结:

运行第二段中的demo可以大体判断timeval来计时相对来说准确一点。这里只是介绍 Linux 平台下 c 语言中计算程序运行时间的方法, 它们各有利弊,依据自己的需要可以使用对应的方法。

附录:http://hi.baidu.com/longchengjiang/blog/item/78de951eec23b61240341737.html   此文作者对时间、滴答的形成进行了较详细的调查

(cyphei)
本站文章除注明转载外,均为本站原创或编译欢迎任何形式的转载,但请务必注明出处,尊重他人劳动,同学习共成长。转载请注明:文章转载自:罗索实验室 [http://www.rosoo.net/a/201201/15625.html]
本文出处:CSDN博客 作者:cyphei 原文
顶一下
(0)
0%
踩一下
(0)
0%
------分隔线----------------------------
相关文章
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
用户名: 验证码:点击我更换图片
栏目列表
将本文分享到微信
织梦二维码生成器
推荐内容