Chinaunix首页 | 论坛 | 博客
  • 博客访问: 327425
  • 博文数量: 243
  • 博客积分: 86
  • 博客等级: 民兵
  • 技术积分: 1045
  • 用 户 组: 普通用户
  • 注册时间: 2012-03-09 17:03
个人简介

稳重,成熟

文章分类

全部博文(243)

文章存档

2015年(2)

2013年(72)

2012年(169)

我的朋友

分类: LINUX

2013-03-19 10:35:39

原文地址:统计程序执行时长 作者:asteriskchina

 #include
 #include
 void main()
 {
   struct timeb t1,t2;
   long t;
   double x,sum=1,sum1;
   int i,j,n;
   printf("请输入x n:");
   scanf("%lf%d",&x,&n);
   ftime(&t1); /* 求得当前时间 */
   for(i=1;i<=n;i++)
   {
     sum1=1;
     for(j=1;j<=i;j++)
       sum1=-sum1/x;
     sum+=sum1;
   }
   ftime(&t2); /* 求得当前时间 */
   t=(t2.time-t1.time)*1000+(t2.millitm-t1.millitm); /* 计算时间差 */
   printf("sum=%lf 用时%ld毫秒\n",sum,t);
 }

主要时间结构体:

1、time_t 类型:长整型,一般用来表示从1970-01-01 00:00:00时以来的秒数,精确度:秒;由函数time()获取;

     该类型定义在头文件 /usr/include/sys/time.h 中:

     #define _TIME_T
       typedef   long   time_t;         /* time of day in seconds */
     #endif  /* _TIME_T */

     函数定义:time_t   time(time_t*  lpt);

     如:time_t   time = time(NULL);

2、struct timeb 结构:它有两个主要成员,一个是秒,另一个是毫秒;精确度:毫秒(10E-3秒)

     由函数ftime()获取struct timeb结构的时间;其定义如下:

     struct timeb

      {
        time_t  time;                     /* time, seconds since the epoch      :秒*/
        unsigned short millitm;     /* 1000 msec of additional accuracy :毫秒 */
        short   timezone;              /* timezone, minutes west of GMT     :时区 */
        short   dstflag;                 /* daylight savings when appropriate :时区标记 */
      };

      #include

      int  ftime(struct  timeb*  tp);

      调用成功返回0;调用失败返回-1;

3、struct  timeval 结构,它有两个成员;一个是秒,另一个表示微秒,精确度:微秒(10E-6)

      由函数gettime0fday()获取;

      struct  timeval结构定义为:

      struct  timeval

      {

          long  tv_sec;     /*  Seconds:  秒*/

          long  tv_usec;   /*  MicroSeconds:微秒*/

      }

      读取struct timeval结构数据的函数说明:

      #include 
      int  gettimeofday(struct  timeval*  tv,struct  timezone*  tz);

      该函数会提取系统当前时间,并把时间分为秒和微秒两部分填充到结构struct  timeval中;同时把当地的时区信

      息填充到结构struct  timezone中;

      返回值:成功则返回0,失败返回-1,错误代码存于errno。附加说明EFAULT指针tv和tz所指的内存空间超出存

      取权限。

      struct  timezone结构的定义为:

      struct  timezone

      {

         int  tz_minuteswest;  /* 和Greenwich 时间差了多少分钟 */ 
         int  tz_dsttime;          /*日光节约时间的状态*/

      }

      上述两个结构都定义在/usr/include/sys/time.h。tz_dsttime 所代表的状态如下 
      DST_NONE /*不使用*/ 
      DST_USA /*美国*/ 
      DST_AUST /*澳洲*/ 
      DST_WET /*西欧*/ 
      DST_MET /*中欧*/ 
      DST_EET /*东欧*/ 
      DST_CAN /*加拿大*/ 
      DST_GB /*大不列颠*/ 
      DST_RUM /*罗马尼亚*/ 
      DST_TUR /*土耳其*/ 
      DST_AUSTALT /*澳洲(1986年以后)*/ 

4、struct  timespec 结构:它是POSIX.4标准定义的一个时间结构,精确度:纳秒(10E-9秒)

      由函数gethrestime()或gethrestime_lasttick()获取当前系统struct  timespec结构的时间;其定义如下:

      struct  timespec                /* definition per POSIX.4 */

      {

          time_t    tv_sec;            /* Seconds         :秒 */

          long       tv_nsec;          /*  Nanoseconds :纳秒 */

     };

     typedef   struct  timespec   timespec_t;

     该结构定义在头头文件 /usr/include/sys/time_impl.h 中;

     extern   void   gethrestime(timespec_t*);
     extern   void   gethrestime_lasttick(timespec_t*);

5、clock_t 类型:由函数clock()获取;

     #include 

     clock_t   clock(void);

     该函数以微秒的方式返回CPU的时间;

     类型 clock_t 定义在头文件/usr/include/sys/types.h中:

     #ifndef _CLOCK_T
     #define _CLOCK_T
      typedef    long   clock_t; /* relative time in a specified resolution */
     #endif  /* ifndef _CLOCK_T */

6、struct  tm 结构:由函数gmtime()解析time_t得到

      struct tm*gmtime(const time_t*timep); 
      函数说明:gmtime()将参数timep 所指的time_t 结构中的信息转换成真实世界所使用的时间日期表示方法,然后

      将结果由结构tm返回。 
      结构tm的定义为 
      struct tm 
      { 
         int   tm_sec; 
         int   tm_min; 
         int   tm_hour; 
         int   tm_mday; 
         int   tm_mon; 
         int   tm_year; 
         int   tm_wday; 
         int   tm_yday; 
         int tm_isdst; 
      }; 
      int   tm_sec 代表目前秒数,正常范围为0-59,但允许至61秒 
      int   tm_min 代表目前分数,范围0-59 
      int   tm_hour 从午夜算起的时数,范围为0-23 
      int   tm_mday 目前月份的日数,范围01-31 
      int   tm_mon 代表目前月份,从一月算起,范围从0-11 
      int   tm_year 从1900 年算起至今的年数 
      int   tm_wday 一星期的日数,从星期一算起,范围为0-6 
      int   tm_yday 从今年1月1日算起至今的天数,范围为0-365 
      int   tm_isdst 日光节约时间的旗标 
      此函数返回的时间日期未经时区转换,而是UTC时间。 
      返回值:返回结构tm代表目前UTC 时间 

7、Unix对时间单位的定义

     #define SEC                1                        // 秒
     #define MILLISEC        1000                  // 毫秒
     #define MICROSEC     1000000            // 微秒
     #define NANOSEC       1000000000      // 纳秒

8、时间格式化函数:

     size_t strftime(char *str,size_t max,char *fmt,struct tm *tp);  strftime有点像sprintf,其格式由fmt来指定。  
     %a : 本第几天名称,缩写
     %A : 本第几天名称,全称
     %b : 月份名称,缩写
     %B : 月份名称,全称
     %c : 与ctime/asctime格式相同
     %d : 本月第几日名称,由零算起
     %H : 当天第几个小时,24小时制,由零算起
     %I : 当天第几个小时,12小时制,由零算起
     %j : 当年第几天,由零算起
     %m : 当年第几月,由零算起
     %M : 该小时的第几分,由零算起
     %p : AM或PM
     %S : 该分钟的第几秒,由零算起
     %U : 当年第几,由第一个日开始计算
     %W : 当年第几,由第一个一开始计算
     %w : 当第几日,由零算起
     %x : 当地日期
     %X : 当地时间
     %y : 两位数的年份
     %Y : 四位数的年份
     %Z : 时区名称的缩写
     %% : %符号


     char * strptime(char *s,char *fmt,struct tm *tp);  如同scanf一样,解译字串成为tm格式
     %h : 与%b及%B同
     %c : 读取%x及%X格式
     %C : 读取%C格式
     %e : 与%d同
     %D : 读取%m/%d/%y格式
     %k : 与%H同
     %l : 与%I同
     %r : 读取"%I:%M:%S %p"格式
     %R : 读取"%H:%M"格式
     %T : 读取"%H:%M:%S"格式
     %y : 读取两位数年份
     %Y : 读取四位数年份


阅读(327) | 评论(0) | 转发(0) |
0

上一篇:单链表常用操作

下一篇:getopt函数应用

给主人留下些什么吧!~~