Fermer un canal indique que nous n’enverrons plus de valeurs dessus. Cela peut être utile pour indiquer au receveur qu’on a terminé. |
|
package main
|
|
import "fmt"
|
|
Dans cet exemple, nous allons utilise un canal |
func main() {
jobs := make(chan int, 5)
done := make(chan bool)
|
Voici la goroutine qui traite les travaux.
Elle reçoit de manière répétée dans |
go func() {
for {
j, more := <-jobs
if more {
fmt.Println("received job", j)
} else {
fmt.Println("received all jobs")
done <- true
return
}
}
}()
|
Cela envoit 3 jobs à travers le canal |
for j := 1; j <= 3; j++ {
jobs <- j
fmt.Println("sent job", j)
}
close(jobs)
fmt.Println("sent all jobs")
|
On attend le worker en utilisation l’approche de synchronisation vue plus tôt. |
<-done
}
|
$ go run closing-channels.go
sent job 1
received job 1
sent job 2
received job 2
sent job 3
received job 3
sent all jobs
received all jobs
|
|
L’idée des canaux fermés amène naturllement à notre
exemple suivant : utiliser |
Exemple suivant: Range sur des canaux.