本文介绍下linux系统下如何获取精确到us的时间值(有时程序需要精确到us),另外,linux如何获取系统时间。
linux系统获取系统时间命令:date
注意:此时间是PDT时间,太平洋时间的标准时间从协调世界时减去8小时(UTC 8),下同,并不是utc时间(世界标准时间),所以此时间应该比东八区时间早8+8=16个小时。
如何获取带时区的时间呢?
linux系统中存在一个环境变量可以控制修改时区—》TZ
此时打印TZ,echo $TZ,没有值,如何设置呢?
使用tzselect命令,最终会形成一条设置TZ的命令
如下:
执行命令
由上图可以看出,TZ的值变成了东八区的时间配置(上海时间)
linux终端至此获取了准确的时间值
这里注意:export的执行只对当前终端有效,重新打开终端后date获取的时间又变成PDT时间
总结为一条(date后跟参数,格式化输出时间,date输出PDT时间):
TZ=‘Asia/Shanghai’; export TZ; date “+%Y-%m-%d %H:%M:%S”
函数1,FILE *popen(const char *command, const char *type);
popen() 函数 用 创建管道 的 方式 启动一个 进程, 并调用 shell. 因为 管道 是被定义成单向的, 所以 type 参数 只能 定义成 只读或者 只写, 不能是 两者同时, 结果流 也相应的 是只读 或者 只写.
command 参数 是 一个 字符串指针, 指向的是 一个 以 null 结束符 结尾的字符串, 这个 字符串包含 一个 shell 命令. 这个命令 被送到 /bin/sh 以 -c 参数 执行, 即由 shell 来执行. type 参数 也是 一个 指向 以 null 结束符结尾的 字符串的指针, 这个字符串 必须是 ‘r’ 或者 'w’ 来指明 是 读还是写.
函数2,int gettimeofday(struct timeval*tv,struct timezone *tz )
功能:获得当前精确时间(1970年1月1日到现在的时间),其参数tv是保存获取时间结果的结构体,参数tz用于保存时区结果
参数:
struct timeval{
long tv_sec;/*秒*/
long tv_usec;/*微妙*/
};
struct timezone{
int tz_minuteswest;/*和greenwich时间差*/
int tz_dsttime;
}
返回值:0为成功,-1为失败
代码实现:
#include
#include
#include
#include
#include
#include
//获取系统时间
int get_systemtime(char * time_now)
{
FILE * fp;
char buf[32];
fp = popen("TZ='Asia/Shanghai'; export TZ; date \"+%Y-%m-%d %H:%M:%S\"","r");
if(fp != NULL)
{
while(NULL != fgets(buf,sizeof(buf),fp))
{
printf("time:%s\n",buf);
}
}
else
{
printf("popen error\n");
return -1;
}
strcpy(time_now,buf);
pclose(fp);
return 0;
}
int main(int argc, const char *argv[])
{
struct timeval tvstart,tvend;
double diff_timems;
int diff_timeus;
char timestring[32];
/*
* struct timeval{
* long int tv_sec; // 秒数
* long int tv_usec; // 微秒数
* }
*/
//此函数为Linux系统中获取微秒级时间的函数。用法如下
gettimeofday(&tvstart,NULL);
sleep(2);
gettimeofday(&tvend,NULL);
printf("start,sec:%ld,usec:%ld\n",tvstart.tv_sec,tvstart.tv_usec);
printf("end,sec:%ld,usec:%ld\n",tvend.tv_sec,tvend.tv_usec);
//时间差,us
diff_timeus = (int)((1000000*(tvend.tv_sec-tvstart.tv_sec))+(tvend.tv_usec-tvstart.tv_usec));
diff_timems = ((double)diff_timeus/1000);
printf("diff time:%lfms,%dus\n",diff_timems,diff_timeus);
//获取系统时间
if(0 > get_systemtime(timestring))
{
printf("get system time fail\n");
}
else
printf("system time:%s\n",timestring);
return 0;
}