go语言从例子开始之Example32.打点器

定时器 是当你想要在未来某一刻执行一次时使用的 - 打点器 则是当你想要在固定的时间间隔重复执行准备的。这里是一个打点器的例子,它将定时的执行,直到我们将它停止。

Example:

package main
import "fmt"
import "time"


func main() {
    //打点器和定时器的机制有点相似:
    //一个通道用来发送数据。
    //这里我们在这个通道上使用内置的 range 来迭代值每隔500ms 发送一次的值。
    ticker := time.NewTicker(time.Millisecond * 500)

    //协程循环遍历。这里如果不用协程,for会一直遍历下去。
    //当开协程后,主线程1600ms后可以stop
    go func(){
        for t := range ticker.C{
            fmt.Println("Tick at:", t)
        }
    }()


    //打点器可以和定时器一样被停止。
    //一旦一个打点停止了,将不能再从它的通道中接收到值。
    //我们将在运行后 1600ms停止这个打点器。
    time.Sleep(time.Millisecond     * 1600)
    ticker.Stop()
    fmt.Println("Ticker stop.")

}

Result:

$ go run example.go
Tick at: 2019-10-29 11:03:22.3623367 +0800 CST m=+0.509760201
Tick at: 2019-10-29 11:03:22.8620829 +0800 CST m=+1.009506401
Tick at: 2019-10-29 11:03:23.3630626 +0800 CST m=+1.510486101
Ticker stop.

相关推荐