内容简介:最近发现程序中有一个时间代码比较老是不对打印nt和at后发现at明明在nt之前,但是nt.After返回了false.打印nt和at的Unix时间戳后发现,at时间增加了8个小时.
问题
最近发现程序中有一个时间代码比较老是不对
at, err := time.Parse("2006-01-02 15:04:05", authTime) if err != nil { return } nt := time.Now() fmt.Println(nt, at) if nt.After(at) { return }
打印nt和at后发现at明明在nt之前,但是nt.After返回了false.
原因
fmt.Println(nt.Unix(), at.Unix())
打印nt和at的Unix时间戳后发现,at时间增加了8个小时.
查看time.Parse文档后发现,这里解析的是UTC时间,与中国时间相差8个小时.
解决
使用time.ParseInLocation即可解决问题
time.ParseInLocation("2006-01-02 15:04:05", authTime, time.Local)
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
深入体验Java Web开发内幕
张孝祥 / 电子工业出版社 / 2007-12 / 55.00元
《深入体验Java Web开发内幕:高级特性》是《深入体验Java Web开发内幕——核心基础》的姊妹篇,Java Web开发的初学者在阅读《深入体验Java Web开发内幕:高级特性》前,应该先学习《深入体验Java Web开发内幕——核心基础》。《深入体验Java Web开发内幕:高级特性》详细阐述了Java Web应用开发中的各种高级特性——Apache文件上传组件的源码分析及应用和编写原理......一起来看看 《深入体验Java Web开发内幕》 这本书的介绍吧!