Tickers

Tickers #

// Les [timers](timers) servent quand on veut faire
// quelquechose dans le futur. Les _tickers_ servent à
// faire quelquechose de manière répétée à intervalles
// réguliers. Voici un exemple d'un ticker qui se répète
// jusqu'à ce qu'on l'arrête.
// intervals. Here's an example of a ticker that ticks
// periodically until we stop it.

package main

import "time"
import "fmt"

func main() {

    // Les tickers utilisent un mécanisme similaire à
    // celui des timers : un canal pour envoyer des
    // valeurs. Ici, nous utilisons la builtin `range`
    // sur le canal pour itérer sur les valeurs
    // lorsqu'elles arrivent, toutes les 500ms.
    ticker := time.NewTicker(time.Millisecond * 500)
    go func() {
        for t := range ticker.C {
            fmt.Println("Tick at", t)
        }
    }()

    // Les tickers peuvent être arrêtés comme les timers.
    // Lorsqu'un ticker est arrêté, il ne recevra plus de
    // valeurs sur son canal. Nous arrêterons le notre
    // après 1600ms.
    time.Sleep(time.Millisecond * 1600)
    ticker.Stop()
    fmt.Println("Ticker stopped")
}
# Quand on lance ce programme, le ticker devrait
# envoyer 3 notifications avant qu'on ne l'arrête.
$ 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