go语言从例子开始之Example32.打点器
2019-10-29 11:06 _天枢 阅读(321) 评论(0) 编辑 收藏 举报定时器 是当你想要在未来某一刻执行一次时使用的 - 打点器 则是当你想要在固定的时间间隔重复执行准备的。这里是一个打点器的例子,它将定时的执行,直到我们将它停止。
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.
作 者:
天枢
出 处:
http://www.cnblogs.com/yhleng/
关于作者:专注于软件自动化测试领域。如有问题或建议,请多多赐教!
版权声明:本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接。
特此声明:所有评论和私信都会在第一时间回复。也欢迎园子的大大们指正错误,共同进步。或者
直接私信我
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角
【
推荐】
一下。您的鼓励是作者坚持原创和持续写作的最大动力!