我们可以认为格林威治时间就是时间协调时间(GMT=UTC)
GMT : 格林威治时间
UTC : 时间协调时间
1、time_t
time_t time(time_t *t);
取得从1970年1月1日至今的秒数。
time_t类型,这本质上是一个长整数( long ),表示从1970-01-01 00:00:00到目前计时时间的秒数,timeval则精确到毫秒
2、timeval
timeval类型,这是一个结构体类型,struct timeval 头文件为 time.h
struct timeval { time_t tv_sec; /* Seconds. */ //秒 suseconds_t tv_usec; /* Microseconds. */ //微秒 };
使用:
struct timeval tv; gettimeofday(&tv, NULL); printf("%d\t%d\n", tv.tv_usec, tv.tv_sec);
3、timezone
struct timezone { int tz_minuteswest; /* minutes west of Greenwich */ int tz_dsttime; /* type of DST correction */ };
4、struct tm
tm结构,这本质上是一个结构体,里面包含了各时间字段
struct tm { int tm_sec; /* seconds after the minute - [0,59] */ int tm_min; /* minutes after the hour - [0,59] */ int tm_hour; /* hours since midnight - [0,23] */ int tm_mday; /* day of the month - [1,31] */ int tm_mon; /* months since January - [0,11] */ int tm_year; /* years since 1900 */ int tm_wday; /* days since Sunday - [0,6] */ int tm_yday; /* days since January 1 - [0,365] */ int tm_isdst; /* daylight savings time flag */ };
其中tm_year表示从1900年到目前计时时间间隔多少年,如果是手动设置值的话,tm_isdst通常取值-1。
功能:
tm结构体包含,年、月、日,时、分、秒
使用:
time_t t_time; struct tm *tmp_ptr = NULL; time(&t_time); printf("t_time = %d.\n", t_time); tmp_ptr = gmtime(&t_time); printf("after gmtime, the time is: \n yday = %d \n wday = %d \n year = %d \n mon = %d \n mday = %d \n hour = %d \n min = %d \n sec = %d \n isdst =%d.\n", tmp_ptr->tm_yday, tmp_ptr->tm_wday, tmp_ptr->tm_year, tmp_ptr->tm_mon, tmp_ptr->tm_mday, tmp_ptr->tm_hour, tmp_ptr->tm_min, tmp_ptr->tm_sec, tmp_ptr->tm_isdst );
打印:
t_time = 1513841065. after gmtime, the time is: yday = 354 wday = 4 year = 117 mon = 11 mday = 21 hour = 7 min = 24 sec = 25 isdst =0.
5、ctime/asctime
char *ctime(const time_t *timep);
将timep转换为真是世界的时间,以字符串显示,它和asctime不同就在于传入的参数形式不一样。
char *asctime(const struct tm* timeptr);
将结构中的信息转换为真实世界的时间,以字符串的形式显示。
char *ctime(const time_t *timer) 返回一个表示当地时间的字符串,当地时间是基于参数 timer。
返回的字符串格式:Thu Dec 21 13:59:57 2017
使用:
time_t curtime; struct tm *tm_ptr = NULL; time(&curtime); tm_ptr = localtime(&curtime); printf("ctime转换的当前时间 = %s", ctime(&curtime)); printf("asctime转换的当前时间 = %s", asctime(tm_ptr));
打印:
ctime转换的当前时间 = Thu Dec 21 13:59:57 2017
asctime转换的当前时间 = Thu Dec 21 13:59:57 2017
6、gmtime/localtime
struct tm* gmtime(const time_t *timep);
将time_t表示的时间转换为没有经过时区转换的UTC时间,是一个struct tm结构指针。
stuct tm* localtime(const time_t *timep);
和gmtime类似,但是它是经过时区转换的时间。
time_t curtime;
gmtime 函数将 curtime 转换为struct tm结构的格林威治时间,基本的意思是,gmtime转出来的是0时区的标准时间
localtime 函数将 curtime 转换为struct tm结构的本地时间,localtime是将时区考虑在内了,转出的当前时区的时间。
举个例子:
time_t t_time; struct tm *tmp_ptr = NULL; time(&t_time); printf("t_time = %d.\n", t_time); tmp_ptr = gmtime(&t_time); printf("after gmtime, the time is: \n yday = %d \n wday = %d \n year = %d \n mon = %d \n mday = %d \n hour = %d \n min = %d \n sec = %d \n isdst =%d.\n", tmp_ptr->tm_yday, tmp_ptr->tm_wday, tmp_ptr->tm_year, tmp_ptr->tm_mon, tmp_ptr->tm_mday, tmp_ptr->tm_hour, tmp_ptr->tm_min, tmp_ptr->tm_sec, tmp_ptr->tm_isdst ); tmp_ptr = localtime(&t_time); printf("after localtime, the time is: \n yday = %d \n wday = %d \n year = %d \n mon = %d \n mday = %d \n hour = %d \n min = %d \n sec = %d \n isdst =%d.\n", tmp_ptr->tm_yday, tmp_ptr->tm_wday, tmp_ptr->tm_year, tmp_ptr->tm_mon, tmp_ptr->tm_mday, tmp_ptr->tm_hour, tmp_ptr->tm_min, tmp_ptr->tm_sec, tmp_ptr->tm_isdst ); return 0;
打印:
t_time = 1513841065. after gmtime, the time is: yday = 354 wday = 4 year = 117 mon = 11 mday = 21 hour = 7 min = 24 sec = 25 isdst =0. after localtime, the time is: yday = 354 wday = 4 year = 117 mon = 11 mday = 21 hour = 15 min = 24 sec = 25 isdst =0.
7、mktime
time_t mktime(struct tm* timeptr);
将struct tm 结构的时间转换为从1970年至今的秒数。
mktime 与 gmtime/localtime 功能相反,gmtime/localtime 将time_t转换为struct tm结构体数据,mktime将struct tm重新转换为time_t类型的UTC时间
使用例子:
time_t t_time; struct tm *tm_ptr = NULL; time(&t_time); printf("time_t first time value = %d.\n", t_time); tm_ptr = gmtime(&t_time); printf("time_t switch gmtime type, the time is: \n yday = %d \n wday = %d \n year = %d \n mon = %d \n mday = %d \n hour = %d \n min = %d \n sec = %d \n isdst =%d.\n", tm_ptr->tm_yday, tm_ptr->tm_wday, tm_ptr->tm_year, tm_ptr->tm_mon, tm_ptr->tm_mday, tm_ptr->tm_hour, tm_ptr->tm_min, tm_ptr->tm_sec, tm_ptr->tm_isdst ); t_time = mktime(tm_ptr); /*重新转换为time_t类型的UTC时间,这里有一个时区的转换, 时间为0区的时间, 所以一下使用的时间都为0区的时间*/ printf("gmtime type switch time_t second time = %d.\n", t_time);
打印:
time_t first time value = 1513842674. time_t switch gmtime type, the time is: yday = 354 wday = 4 year = 117 mon = 11 mday = 21 hour = 7 min = 51 sec = 14 isdst =0. gmtime type switch time_t second time = 1513813874.
8、gettimeofday
int gettimeofday(struct timeval *tv, struct timezone *tz);
返回当前距离1970年的秒数和微妙数,后面的tz是时区,一般不用。
使用例子:
struct timeval time_val; gettimeofday(&time_val, NULL); //gettimeofday(&start,&tz);结果一样 printf("时间秒.tv_sec: %d.\n",time_val.tv_sec); printf("时间微秒.tv_usec: %d.\n",time_val.tv_usec);
打印:
时间秒.tv_sec:1513843633 时间微秒.tv_usec:689374
9、difftime
double difftime(time_t time1, time_t time2);
返回两个时间相差的秒数
使用例子:
//获得时间差 time_t t_start; time_t t_end; time(&t_start); sleep(5); time(&t_end); printf("间隔时间= %f.\n", difftime(t_end, t_start));
打印:
间隔时间= 5.000000.
10、strftime
size_t strftime( char *strDest, size_t maxsize, const char *format, const struct tm *timeptr);
使用strftime()函数将时间格式化为我们想要的格式。
( %a 星期几的简写 %A 星期几的全称 %b 月分的简写 %B 月份的全称 %c 标准的日期的时间串 %C 年份的后两位数字 %d 十进制表示的每月的第几天 %D 月/天/年 %e 在两字符域中,十进制表示的每月的第几天 %F 年-月-日 %g 年份的后两位数字,使用基于周的年 %G 年分,使用基于周的年 %h 简写的月份名 %H 24小时制的小时 %I 12小时制的小时 %j 十进制表示的每年的第几天 %m 十进制表示的月份 %M 十时制表示的分钟数 %n 新行符 %p 本地的AM或PM的等价显示 %r 12小时的时间 %R 显示小时和分钟:hh:mm %S 十进制的秒数 %t 水平制表符 %T 显示时分秒:hh:mm:ss %u 每周的第几天,星期一为第一天 (值从0到6,星期一为0) %U 第年的第几周,把星期日做为第一天(值从0到53) %V 每年的第几周,使用基于周的年 %w 十进制表示的星期几(值从0到6,星期天为0) %W 每年的第几周,把星期一做为第一天(值从0到53) %x 标准的日期串 %X 标准的时间串 %y 不带世纪的十进制年份(值从0到99) %Y 带世纪部分的十进制年份 %z,%Z 时区名称,如果不能得到时区名称则返回空字符。 %% 百分号 )
使用例子:
time_t t_time; char buf[128]; struct tm* tm_ptr = NULL; time(&t_time); tm_ptr = localtime(&t_time); //2017-12-21 18:53:58 strftime(buf, 64, "%Y-%m-%d %H:%M:%S", tm_ptr); strftime(buf, 64, "%Y-%m-%d --- %H:%M:%S", tm_ptr); printf("formatTimeString = %s.\n", buf);
打印:
formatTimeString = 2017-12-21 18:53:58. formatTimeString = 2017-12-21 --- 18:54:46.
11、strptime
功能和 strftime 功能相反, 将字符串格式化为一个tm结构。
size_t strftime(char *s,size_t maxsize,char *format,const struct tm *timeptr);
使用例子:
char buf[] = "2017-12-21 --- 18:54:46"; struct tm tm_ptr; //2017-12-21 18:53:58 strptime(buf, "%Y-%m-%d --- %H:%M:%S", &tm_ptr); printf("----strptime-----, the time is: \n yday = %d \n wday = %d \n year = %d \n mon = %d \n mday = %d \n hour = %d \n min = %d \n sec = %d.\n", tm_ptr.tm_yday, tm_ptr.tm_wday, tm_ptr.tm_year, tm_ptr.tm_mon, tm_ptr.tm_mday, tm_ptr.tm_hour, tm_ptr.tm_min, tm_ptr.tm_sec );
打印:
----strptime-----, the time is: yday = 354 wday = 4 year = 117 mon = 11 mday = 21 hour = 18 min = 54 sec = 46.
以上这篇liunx 时间函数与时间格式与字符串之间的转化方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
- 《暗喻幻想》顺风耳作用介绍
- 崔健1985-梦中的倾诉[再版][WAV+CUE]
- 黄子馨《追星Xin的恋人们2》HQ头版限量编号[WAV+CUE]
- 孟庭苇《情人的眼泪》开盘母带[低速原抓WAV+CUE]
- 孙露《谁为我停留HQCD》[低速原抓WAV+CUE][1.1G]
- 孙悦《时光音乐会》纯银CD[低速原抓WAV+CUE][1.1G]
- 任然《渐晚》[FLAC/分轨][72.32MB]
- 英雄联盟新英雄安蓓萨上线了吗 新英雄安蓓萨技能介绍
- 魔兽世界奥杜尔竞速赛什么时候开启 奥杜尔竞速赛开启时间介绍
- 无畏契约CGRS准星代码多少 CGRS准星代码分享一览
- 张靓颖.2012-倾听【少城时代】【WAV+CUE】
- 游鸿明.1999-五月的雪【大宇国际】【WAV+CUE】
- 曹方.2005-遇见我【钛友文化】【WAV+CUE】
- Unity6引擎上线:稳定性提升、CPU性能最高提升4倍
- 人皇Sky今日举行婚礼!电竞传奇步入新篇章