linux c 获取系统时间

使用C语言编写程序需要获得当前精确时间(1970年1月1日到现在的时间),或者为执行计时,可以使用gettimeofday()函数。

#include <sys/time.h>
int gettimeofday(struct  timeval*tv, struct timezone *tz);
其参数tv是保存获取时间结果的结构体,参数tz用于保存时区结果:
struct timezone{
int tz_minuteswest;/*格林威治时间往西方的时差*/
int tz_dsttime;/*DST 时间的修正方式*/
}
timezone 参数若不使用则传入NULL即可。
而结构体 timeval的定义为:
struct timeval{
long int tv_sec; // 秒数
long int tv_usec; // 微秒数
}
它获得的时间精确到微秒(1e-6 s)量级。在一段代码前后分别使用gettimeofday可以计算代码执行时间:
struct timeval tv_begin, tv_end;
gettimeofday(&tv_begin, NULL);
foo();
gettimeofday(&tv_end, NULL);
下面来看一个demo,怎样获取系统当前时间(用ms表示,并且获取程序段运行时间)


#include <stdio.h>
#include <sys/time.h>
#include <time.h>
int  gettimeofday( struct  timeval *tv,  struct  timezone *tz);
int  main( int  argc, char  * argv[])
{
struct  timeval t_start,t_end;
long  cost_time = 0;
//get start time
gettimeofday(&t_start, NULL);
long  start = (( long )t_start.tv_sec)*1000+( long )t_start.tv_usec/1000;
printf ( "Start time: %ld ms\n" , start);
sleep(2);
usleep(5000); //5毫秒
//get end time
gettimeofday(&t_end, NULL);
long  end = (( long )t_end.tv_sec)*1000+( long )t_end.tv_usec/1000;
printf ( "End time: %ld ms\n" , end);
//calculate time slot
cost_time = end - start;
printf ( "Cost time: %ld ms\n" , cost_time);
return  0;
}

其中,long start = ((long)t_start.tv_sec)*1000+(long)t_start.tv_usec/1000;

用来表示,当前获取的系统时间,用毫秒来表示

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值