gettimeofday函数的简单使用及功能说明


gettimeofday函数的功能是引用系统定义的结构体struct timeval,来计算当前程序或者进程,也就是占有CPU的时间是多少,它可以精确到微秒级别。它是通过前后两次调用的时间差来确定所消耗的时间。

struct timeval的原型在#include<sys/time.h>头文件中定义

struct timeval {
               time_t      tv_sec;     /* seconds */
               suseconds_t tv_usec;    /* microseconds */
           };

 

#include<stdio.h>
#include<sys/time.h> 
#include<unistd.h>

int test(int num)
{
//这里用来表示你自己要运行的程序

	while(time--)
	{};
 
}

int main()
{
    //定义两个结构体,来记录开始和结束时间
        struct  timeval start;
        struct  timeval end;
        //记录两个时间差
        unsigned  long diff;

        //获取开始前的瞬间时间
        gettimeofday(&start,NULL);

        //运行自己的程序,消耗时间
        test(1000000);

        //获取程序运行结束那一刻的时间
        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;
}

运行结果:num=1000000时:doubleh@ubuntu:/mnt/hgfs/winshare/C_test$ ./a.out
thedifference is 2318

 

 

 

  • 3
    点赞
  • 32
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值