在tick.go当中,最主要的类是Ticker。它是一个包含了Time类型信道和runtimeTimer类型的计时器的一个包装类。同时还提供了一个生成Ticker实例的一个函数:func NewTicker(d Duration) *Ticker
。
在背后,它初始化了它的runtimeTimer,这是在sleep.go当中定义的,功能是睡眠一定时间、向信道当中放入内容、继续睡眠。这很适合作为Ticker,因此在使用的适合只需要不断从Ticker.C当中读取数据就是对应的Tick了。
如果需要停止,则使用func (t *Ticker) Stop()
。这个函数会停止这个Ticker,以及其内部的那个runtimeTimer。
此外,如果这个Ticker打算常驻,可以直接使用func Tick(d Duration) <-chan Time
。这会帮你生成一个Ticker,并将其中的C暴露出来返回给调用者。但是这样就无法访问Ticker了,因此除非是常驻后台的Ticker,否则这样会导致垃圾泄漏。
写不出来更多的内容了,因为这个代码文件的长度就没几行,大多数都是注释。就这样吧。