gobyexample-tickers

来源:https://github.com/xg-wang/gobyexample/tree/master/examples

//_打点器_则是当你需要在固定的时间间隔重复执行准备的。
package main

import (
    "fmt"
    "time"
)

func main() {
    //打点器和定时器的机制有点相似:一个通道用来发送数据。
    //通常在这个通道上使用内置的`range`来迭代每隔一定时间发送一次的值
    ticker := time.NewTicker(time.Millisecond * 500)
    go func() {
        for t := range ticker.C {
            fmt.Println("Tick at", t)
        }
    }()

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

输出结果:

Tick at 2018-11-01 16:30:23.0158297 +0800 CST m=+0.505190801
Tick at 2018-11-01 16:30:23.5160774 +0800 CST m=+1.005438501
Tick at 2018-11-01 16:30:24.0161102 +0800 CST m=+1.505471301
Ticker stopped

你可能感兴趣的:(gobyexample-tickers)