go语言从例子开始之Example32.打点器
Posted yhleng
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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.
以上是关于go语言从例子开始之Example32.打点器的主要内容,如果未能解决你的问题,请参考以下文章