我有一个headache时间。我有上面的代码:
// ticker := time.NewTicker(time.Minute * 1)
ticker := time.NewTicker(time.Second * 1)
defer ticker.Stop()
// new version
for t := range ticker.C {
// get duration
go func() {
now := time.Now()
const layout = "2006-01-02 15:04:05"
endDateStr := fmt.Sprintf("%04d-%02d-%02d 23:45:00", now.Year(), now.Month(), now.Day())
endDate, _ := time.Parse(layout, endDateStr)
duration := endDate.Sub(now)
drHours := (duration.Minutes() - math.Mod(duration.Minutes(), 60)) / 60
drMinutes := math.Mod(duration.Minutes(), 60)
//fmt.Println(duration.Hours())
fmt.Println(now)
fmt.Println(endDate)
durStr := fmt.Sprintf("%d:%d:00", uint64(drHours), uint64(drMinutes))
fmt.Printf("duration: %s\n", durStr)
}()
fmt.Println(t)
}
在我的compnow并且endDate有不同的时区:
2015-11-12 10:33:53.9298552 +0500 UZT // now
2015-11-12 23:45:00 +0000 UTC // endDate
这就是为什么会得到错误的持续时间。如何为它们设置相同的时区?又是一个问题,注意第一次和第二次tik的持续时间相差5小时。为什么会出现这些问题。我究竟做错了什么?你有什么主意吗 ?让我高兴从你的任何提示?
PIPIONE
森林海
相关分类