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