★time | time包提供了时间的显示和测量用的函数.
time
time包提供了时间的显示和测量用的函数.
time包提供了最基本的时间计量结构Time,Duration,Location
时间打印格式如下:
2019-12-18 21:45:32.987483681 +0800 CST m=+0.000048086
年-月-日 小时:分钟:秒.纳秒 时区 m=+xxx.xxxxxxx
- UTC:协调世界时(Universal Time Coordinated),UTC相当于本初子午线(即经度0度)上的平均太阳时,北京时间比UTC时间早8小时
- CST:CST可能就是北京时间?China Standard Time
- m=+xxx.xxxxxxx:这里的xxxxxxx为与程序执行开始时间的时间偏移,纳秒粒度
Time
Time不应使用指针去传递,结构如下:
type Time struct {
// 用了两个变量去储存时间,一个存秒,一个存纳秒
// 注释还解释了储存方法
wall uint64
ext int64
// 用来表示时区,`loc==nil`代表UTC时区
loc *Location
}
Timer注释长的一批,总体思想如下:
- 精度是纳秒
- Time应该用值传递去储存而不是*Timer
- 有几个方法不是并发安全的:
GobDecode
,UnmarshalBinary
,UnmarshalJSON
和UnmarshalText
- 不要用 == 运算符去比较时间,因为此运算符会去比较Location是否相同,总之用Time自带方法就OK
看完了注释来康一下可以返回Time对象函数吧:
func Unix(sec int64, nsec int64) Time
func Date(year int, month Month, day, hour, min, sec, nsec int, loc *Location) Time
func Parse(layout, value string) (Time, error)
func Now() Time
Duration
定义如下:
type Duration int64
粒度为纳秒,最长表示时间290年
Location
定义如下:
type Location struct {
name string
zone []zone
tx []zoneTrans
// 一丢丢注释
cacheStart int64
cacheEnd int64
cacheZone *zone
}
time包提供了两种计时器Timer和Ticker
Timer
顾名思义,计时器,经过一段时间间隔后触发[1],类似于JS中的SetTimeout()。通过func NewTimer(d Duration) *Timer
函数返回Timer对象指针,其结构如下:
type Timer struct {
C <-chan Time
r runtimeTimer
}
这里触发的意思即,到达时间后Timer.C这个通道不再阻塞,所以可以通过<-time.NewTimer(5*time.Second).C
将程序在此阻塞5秒,5秒过后通道被写入当前的时间对象Time(Time对象,不是Timer),若Timer不活跃将一直阻塞。
Timer的可用方法如下:
-
func (t *Timer) Reset(d Duration) bool
:复用当前Timer,返回Timer在Reset前是否活跃 -
func (t *Timer) Stop() bool
:停止当前Timer,返回Timer在Stop前是否活跃
PS:After(d Duration) <-chan Time
是一种封装好的更简单的用法
PS:AfterFunc(d Duration, f func()) *Timer
是一种回回调式的用法,将runtimeTimer的f改写为goFunc,并将func注册刀arg中,意为时间到后go arg.(func())()
,即开协程运行func
Ticker
这里的Ticker中文意思为“滴答”,指的是周期性的发出滴答的声音,即定期触发,类似于JS中的SetInterval()。通过func NewTicker(d Duration) *Ticker
函数返回Ticker对象指针,其结构如下:
type Ticker struct {
C <-chan Time // The channel on which the ticks are delivered.
r runtimeTimer
}
和Timer结构很类似,两者的差别就是Ticker在初始化时会额外对runtimeTimer结构体的period字段赋值int64(d)
,意为周期执行。
另外Timer没有Reset函数,使用Stop函数同样会让Ticker停下。这时候Ticker就会永久阻塞(我觉得应该是这样)
PS:Tick(d Duration) <-chan Time
是一种封装好的更简单的用法
PPS:func Sleep(d Duration)
是一个与上两种相似用处但功能更简单的函数,不会返回当前时间
有疑问加站长微信联系(非本文作者)