Go by Example: Tickers

Timers son para cuando quieres hacer algo una vez en el futuro - tickers son para cuando quieres hacer algo repetidamente a intervalos regulares. Aquí hay un ejemplo de un ticker que marca periódicamente hasta que lo detenemos.

package main
import (
    "fmt"
    "time"
)
func main() {

Los tickers usan un mecanismo similar a los temporizadores: un canal que recibe valores. Aquí usaremos el select incorporado en el canal para esperar los valores a medida que llegan cada 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)
            }
        }
    }()

Los tickers pueden detenerse como los temporizadores. Una vez que un ticker se detiene, no recibirá más valores en su canal. Detendremos el nuestro después de 1600ms.

    time.Sleep(1600 * time.Millisecond)
    ticker.Stop()
    done <- true
    fmt.Println("Ticker stopped")
}

Cuando ejecutamos este programa, el ticker debería marcar 3 veces antes de que lo detengamos.

$ 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

Siguiente ejemplo: Worker Pools.