Go by Example: Tickers

英文源地址
Timers是为你将来想做某事的时候准备的–tickers是为你想定期重复做某事的时候准备的.这里有一个ticker的例子, 它会周期性地tick, 直到我们停止它.

package main

import (
	"fmt"
	"time"
)

func main() {
    
    
	// ticker的使用于timer是类似的机制: 发送值的通道
	// 在这里, 我们将使用select在通道上等待每500ms到达一次的值.
	ticker := time.NewTicker(500 * time.Millisecond)
	done := make(chan bool)

	go func() {
    
    
		for {
    
    
			select {
    
    
			case <-done:
				return
			case t := <-ticker.C:
				fmt.Println("Tick at", t)
			}
		}
	}()

	// ticker可以像计时器一样停止
	// 一旦一个ticker停止, 它将不会在其通道上接收任何更多的值.
	// 我们将在1600毫秒后停止
	time.Sleep(1600 * time.Millisecond)
	ticker.Stop()
	done <- true
	fmt.Println("Ticker stopped")
}

当我们运行这个程序时, 在我们停止它之前, 它应该tick3次.

$ go run tickers.go
Tick at 2012-09-23 11:29:56.487625 -0700 PDT
Tick at 2012-09-23 11:29:56.988063 -0700 PDT
Tick at 2012-09-23 11:29:57.488076 -0700 PDT
Ticker stopped

下一节将介绍: Worker Pools.

猜你喜欢

转载自blog.csdn.net/weixin_43547795/article/details/130871898
今日推荐