关于用编程 取本地时间时,会有夏令时的坑,

[zhenmu@zhenmu ~]$ TZ='GST-1'; export TZ
[zhenmu@zhenmu ~]$ date +'%Y-%m-%d %H:%M:%S' -d @1583712000
2020-03-09 01:00:00
[zhenmu@zhenmu ~]$ date +'%Y-%m-%d %H:%M:%S' -d @1592352000
2020-06-17 01:00:00

[zhenmu@zhenmu ~]$ TZ='Europe/Berlin'; export TZ
[zhenmu@zhenmu ~]$ date +'%Y-%m-%d %H:%M:%S' -d @1583712000
2020-03-09 01:00:00
[zhenmu@zhenmu ~]$ date +'%Y-%m-%d %H:%M:%S' -d @1592352000
2020-06-17 02:00:00

[zhenmu@zhenmu ~]$ TZ='Asia/Shanghai'; export TZ
[zhenmu@zhenmu ~]$ date +'%Y-%m-%d %H:%M:%S' -d @1583712000
2020-03-09 08:00:00
[zhenmu@zhenmu ~]$ date +'%Y-%m-%d %H:%M:%S' -d @1592352000
2020-06-17 08:00:00
[zhenmu@zhenmu ~]$ 

看以上 "+1时区" 和 "柏林时区" 设置之后查询同一个时间戳,  夏天和冬天有差异!

也就是 localtime localtime_r获取出的时间 和可能电脑显示的不对。
struct tm的结构体大体是这样的,可以看到结果里会告知是否实行了夏令制:


struct tm {

int tm_sec; /* 秒 – 取值区间为[0,59] */

int tm_min; /* 分 - 取值区间为[0,59] */

int tm_hour; /* 时 - 取值区间为[0,23] */

int tm_mday; /* 一个月中的日期 - 取值区间为[1,31] */

int tm_mon; /* 月份(从一月开始,0代表一月) - 取值区间为[0,11] */

int tm_year; /* 年份,其值等于实际年份减去1900 */

int tm_wday; /* 星期 – 取值区间为[0,6],其中0代表星期天,1代表星期一,以此类推 */

int tm_yday; /* 从每年的1月1日开始的天数 – 取值区间为[0,365],其中0代表1月1日,1代表1月2日,以此类推 */

int tm_isdst; /* 夏令时标识符,实行夏令时的时候,tm_isdst为正。不实行夏令时的时候,tm_isdst为0;不了解情况时,tm_isdst()为负。

long int tm_gmtoff; /*指定了日期变更线东面时区中UTC东部时区正秒数或UTC西部时区的负秒数*/

const char *tm_zone; /*当前时区的名字(与环境变量TZ有关)*/

};



网上还看到一个有趣的,代码取出来差了5分32秒的特殊情况:
https://www.cnblogs.com/superch0054/p/4010012.html

你可能感兴趣的:(服务器,linux,服务器)