高冷时区夏令时不起作用



我知道在2014年10月26日凌晨02:00,时钟应该倒退1小时,但我无法使用简单的golang程序再现这一点

const timeFormat = "2 Jan, 2006 3:04pm"
loc, err := time.LoadLocation("Europe/Moscow")
log.Print(loc, err)
testz , _ := time.ParseInLocation( timeFormat, "26 Oct, 2014 01:59am",  loc)
fmt.Println( testz , testz.UTC())
testz = testz.Add( time.Minute )
fmt.Println( testz , testz.UTC())
testz = testz.Add( time.Minute )
fmt.Println( testz , testz.UTC())

输出

2014-10-26 01:59:00 +0300 MSK 2014-10-25 22:59:00 +0000 UTC
2014-10-26 02:00:00 +0300 MSK 2014-10-25 23:00:00 +0000 UTC
2014-10-26 02:01:00 +0300 MSK 2014-10-25 23:01:00 +0000 UTC

go 1.6,linux

给定您的输出,它看起来像这样的行:

testz , _ := time.ParseInLocation(timeFormat, "26 Oct, 2014 01:59am", loc)

实际上是在凌晨1点59分两次出现的之后,因为它显示了+3的偏移。换言之,你看到的时间比你想要的晚了三分钟一小时——从夏令时转换后近一小时开始。

您可以更改您的代码,以这样一个明确的值开始:

testz, _ := time.ParseInLocation(timeFormat, "26 Oct, 2014 00:59am", loc)
testz = testz.Add(time.Hour)

我希望它能显示

2014-10-26 01:59:00 +0400 MSK 2014-10-25 21:59:00 +0000 UTC
2014-10-26 01:00:00 +0300 MSK 2014-10-25 22:00:00 +0000 UTC
2014-10-26 01:01:00 +0300 MSK 2014-10-25 22:01:00 +0000 UTC

(我还没有尝试过,因为我没有安装Go,但我希望它能工作。)

这并不是因为你的代码有错误,只是因为time.UTC()会打印UTC时间,也就是时区0时间,从你的代码time.LoadLocation("Europe/Moscow")我们可以知道你可能在莫斯科,它属于东时区3,所以时间会比UTC时间早三个小时,这意味着<您的时间>=<utc时间>+3。

最新更新