gettimeofday()函数的使用方法

1.简介:

C语言中可以使用函数gettimeofday()函数来得到时间。它的精度可以达到微妙

 

2.函数原型:

#include<sys/time.h>

 

int gettimeofday(struct  timeval*tv,struct  timezone *tz )

 

3.说明:

gettimeofday()会把目前的时间用tv 结构体返回,当地时区的信息则放到tz所指的结构中

 

4.结构体:

1>timeval

 

struct  timeval{

 

    

 

       long  tv_sec;/**/

 

       long  tv_usec;/*微妙*/

 

}

 

2>timezone 结构定义为:

 

struct  timezone{

 

        int tz_minuteswest;/*greenwich 时间差了多少分钟*/

 

        int tz_dsttime;/*type of DST correction*/

 

}

 

3>gettimeofday()函数中tv或者tz都可以为空。如果为空则就不返回其对应的结构体。

 

4>函数执行成功后返回0,失败后返回-1,错误代码存于errno中。

 

5.程序实例:

#include<stdio.h>

#include<sys/time.h>

 

#include<unistd.h>

 

 

 

int main()

 

{

 

        struct  timeval    tv;

 

        struct  timezone   tz;

 

        gettimeofday(&tv,&tz);

 

 

 

        printf(tv_sec:%d\n,tv.tv_sec);

 

        printf(tv_usec:%d\n,tv.tv_usec);

 

        printf(tz_minuteswest:%d\n,tz.tz_minuteswest);

 

        printf(tz_dsttime:%d\n,tz.tz_dsttime);

 

}

 

说明:在使用gettimeofday()函数时,第二个参数一般都为空,因为我们一般都只是为了获得当前时间,而不用获得timezone的数值

 

本篇文章来源于 Linux公社网站(www.linuxidc.com)  原文链接:http://www.linuxidc.com/Linux/2012-06/61903.htm

.gettimeofday()函数的一个常用方法

在测试程序时,往往需要了解程序执行所需的时间,在Linux中可以使用函数gettimeofday来得到时间.

 

1.程序实例:

 

测试调用delya()函数所需执行的时间(单位为微妙)

 

#include<stdio.h>

 

#include<sys/time.h>

 

#include<unistd.h>

 

 

 

int delay(int time)

 

{

 

    int i,j;

 

    

 

    for(i =0;i<time;i++)

 

        for(j=0;j<5000;j++)

 

            ;

 

}

 

 

 

int main()

 

{

 

        struct  timeval start;

 

        struct  timeval end;

 

        

 

        unsigned  long diff;

 

        gettimeofday(&start,NULL);

 

        delay(10);

 

        gettimeofday(&end,NULL);

 

diff = 1000000 * (end.tv_sec-start.tv_sec)+ end.tv_usec-start.tv_usec;

 

        printf(thedifference is %ld\n,diff);

 

        return 0;

 

        

 

}

 

说明:

 

使用该方法就可以检测出调用delay()函数所使用的时间

 

本篇文章来源于 Linux公社网站(www.linuxidc.com)  原文链接:http://www.linuxidc.com/Linux/2012-06/61903p2.htm

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值