Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1778884
  • 博文数量: 198
  • 博客积分: 4088
  • 博客等级: 上校
  • 技术积分: 2391
  • 用 户 组: 普通用户
  • 注册时间: 2011-05-15 16:29
个人简介

游戏开发,系统架构; 博客迁移到:http://www.jianshu.com/u/3ac0504b3b8c

文章分类

全部博文(198)

文章存档

2017年(1)

2016年(12)

2015年(1)

2014年(3)

2013年(13)

2012年(18)

2011年(150)

分类: C/C++

2011-06-23 20:43:30

Linux下对时间进行运算,如果是到秒级的,相信大家都用过time之类的函数实现了,但要更精确些呢?到毫秒、微秒级呢? 

  看看下面这段源代码就明白了: 

#include   
#include   
#include   

void   function()/*用来耗用一定的时间而已,无实际用处的函数*/ 

unsigned   int   i,j; 
double   y; 
for(i=0;i <10000;i++) 
for(j=0;j <10000;j++) 
y=sin((double)i); 


int   main(int   argc,   char   **   argv) 

struct   timeval   tpstart,tpend; 
float   timeuse; 

gettimeofday(&tpstart,NULL); 
function(); 
gettimeofday(&tpend,NULL); 
timeuse=1000000*(tpend.tv_sec-tpstart.tv_sec)+tpend.tv_usec-tpstart.tv_usec; 
timeuse/=1000000; 
printf( "Used   Time:%f\n ",timeuse); 
exit(0); 


  主要是用到了gettimeofday函数,函数里用到了这个结构: 

struct   timeval   { 
long   tv_sec;   /*   seconds   */ 
long   tv_usec;   /*   microseconds   */ 
};
转载地址:
阅读(1044) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~