英文源地址
Timers是为你将来想做某事的时候准备的–tickers是为你想定期重复做某事的时候准备的.这里有一个ticker的例子, 它会周期性地tick, 直到我们停止它.
package mainimport ("fmt""time")func main() {// ticker的使用于timer是类似的机制: 发送值的通道// 在这里, 我们将使用select在通道上等待每500ms到达一次的值.ticker := time.NewTicker(500 * time.Millisecond)done := make(chan bool)go func() {for {select {case <-done:returncase t := <-ticker.C:fmt.Println("Tick at", t)}}}()// ticker可以像计时器一样停止// 一旦一个ticker停止, 它将不会在其通道上接收任何更多的值.// 我们将在1600毫秒后停止time.Sleep(1600 * time.Millisecond)ticker.Stop()done <- truefmt.Println("Ticker stopped")}
当我们运行这个程序时, 在我们停止它之前, 它应该tick3次.
$ go run tickers.goTick at -09-23 11:29:56.487625 -0700 PDTTick at -09-23 11:29:56.988063 -0700 PDTTick at -09-23 11:29:57.488076 -0700 PDTTicker stopped
下一节将介绍: Worker Pools.