Закрытие канала показывает, что больше нельзя будет отправить значения через него. Это может быть полезно для сообщения о завершении приёмникам канала. |
|
package main
|
|
import "fmt"
|
|
В этом примере используется канал |
func main() {
jobs := make(chan int, 5)
done := make(chan bool)
|
Это рабочая горутина. Она постоянно получает данные из
|
go func() {
for {
j, more := <-jobs
if more {
fmt.Println("received job", j)
} else {
fmt.Println("received all jobs")
done <- true
return
}
}
}()
|
Отправляем 3 задачи рабочей горутине через
канал |
for j := 1; j <= 3; j++ {
jobs <- j
fmt.Println("sent job", j)
}
close(jobs)
fmt.Println("sent all jobs")
|
Ждем рабочую горутину используя подход синхронизации, который был рассмотрен ранее. |
<-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
|
|
Идея закрытых каналов естественно приводит к следующему примеру: перебор значений каналов. |
Следующий пример: Перебор значений каналов (Range over Channels).