linux 获取时间差

  [转]linux下获得时间差,精确到微秒级别  2008-03-12 10:05:45

分类:

最近需要测算软件计算FFT所需要的时间,所收集参考的资料:
 
 
#include     
  #include                                                   /*   包含标准库头文件   */   
  #include     
    
  int   main(int   argc,   char   **argv)   
  {   
  struct   timeval   start,stop,diff;   
  gettimeofday(&start,0);   
                    //做你要做的事...   
  gettimeofday(&stop,0);   
  timeval_subtract(&diff,&start,&stop);   
                    printf("总计用时:%d 微秒n",diff.tv_usec);   
  }                     
    
  /**   
      *   计算两个时间的间隔,得到时间差   
      *   @param   struct   timeval*   resule   返回计算出来的时间   
      *   @param   struct   timeval*   x             需要计算的前一个时间   
      *   @param   struct   timeval*   y             需要计算的后一个时间   
      *   return   -1   failure   ,0   success   
  **/   
  int   timeval_subtract(struct   timeval*   result,   struct   timeval*   x,   struct   timeval*   y)   
  {   
        int   nsec;   
    
        if   (   x->tv_sec>y->tv_sec   )   
                  return   -1;   
    
        if   (   (x->tv_sec==y->tv_sec)   &&   (x->tv_usec>y->tv_usec)   )   
                  return   -1;   
    
        result->tv_sec   =   (   y->tv_sec-x->tv_sec   );   
        result->tv_usec   =   (   y->tv_usec-x->tv_usec   );   
    
        if   (result->tv_usec<0)   
        {   
                  result->tv_sec--;   
                  result->tv_usec+= 1000000;   
        }   
    
        return   0;   
  }   
   
 
--------------------------------------------------
#include     
  #include     
  int   gettimeofday(struct   timeval   *tv,struct   timezone   *tz);   
  功能:将目前的时间以tv所指的结构返回。   
  struct   timeval{   
          long   tv_sec;//秒   
          long   tv_usec;//微秒   
  };   
  将其中的tv_usec转换到毫秒即可。   
  timezone结构自己查吧
 
 
 
附录:
-------------------------------------------------
Linux下获得系统时间的C语言的实现方法   
  #include     //C语言的头文件   
  #include     //C语言的I/O   
    
  void   main()   
  {   
  time_t   now;         //实例化time_t结构   
  struct   tm     *timenow;         //实例化tm结构指针   
  time(&now);   
  //time函数读取现在的时间(国际标准时间非北京时间),然后传值给now   
    
  timenow   =   localtime(&now);   
  //localtime函数把从time取得的时间now换算成你电脑中的时间(就是你设置的地区)   
    
  printf("Local   time   is   %sn",asctime(timenow));   
  //上句中asctime函数把时间转换成字符,通过printf()函数输出   
  }   
    
  注释:time_t是一个在time.h中定义好的结构体。而tm结构体的原形如下:   
    
  struct   tm   
  {   
      int   tm_sec;//seconds   0-61   
      int   tm_min;//minutes   1-59   
      int   tm_hour;//hours   0-23   
      int   tm_mday;//day   of   the   month   1-31   
      int   tm_mon;//months   since   jan   0-11   
      int   tm_year;//years   from   1900   
      int   tm_wday;//days   since   Sunday,   0-6   
      int   tm_yday;//days   since   Jan   1,   0-365   
      int   tm_isdst;//Daylight   Saving   time   indicator   
  };   

0

上一篇:DataTable,DataView和DataGrid比较

下一篇:[转]主设备号与次设备号

相关热门文章
  • 承接自动化测试培训、外包、实...
  • Solaris PowerTOP 1.0 发布
  • For STKMonitor
  • 项目小体会
  • phpStudy 2010下载,PHP5开发...

你可能感兴趣的:(网络编程)