码迷,mamicode.com
首页 > 编程语言 > 详细

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

时间:2019-10-29 11:49:53      阅读:88      评论:0      收藏:0      [点我收藏+]

标签:color   lan   停止   bsp   执行   发送   ref   code   mil   

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

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.

 

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

标签:color   lan   停止   bsp   执行   发送   ref   code   mil   

原文地址:https://www.cnblogs.com/yhleng/p/11757612.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!