Closing Channels->通道的关闭
#
// _关闭_ 一个通道意味着不能再向这个通道发送值了。
// 该特性可以向通道的接收方传达工作已经完成的信息。
package main
import "fmt"
// 在这个例子中,我们将使用一个 `jobs` 通道,将工作内容,
// 从 `main()` 协程传递到一个工作协程中。
// 当我们没有更多的任务传递给工作协程时,我们将 `close` 这个 `jobs` 通道。
func main() {
jobs := make(chan int, 5)
done := make(chan bool)
// 这是工作协程。使用 `j, more := <- jobs` 循环的从 `jobs` 接收数据。
// 根据接收的第二个值,如果 `jobs` 已经关闭了,
// 并且通道中所有的值都已经接收完毕,那么 `more` 的值将是 `false`。
// 当我们完成所有的任务时,会使用这个特性通过 `done` 通道通知 main 协程。
go func() {
for {
j, more := <-jobs
if more {
fmt.Println("received job", j)
} else {
fmt.Println("received all jobs")
done <- true
return
}
}
}()
// 使用 `jobs` 发送 3 个任务到工作协程中,然后关闭 `jobs`。
for j := 1; j <= 3; j++ {
jobs <- j
fmt.Println("sent job", j)
}
close(jobs)
fmt.Println("sent all jobs")
// 使用前面学到的[通道同步](channel-synchronization)方法等待任务结束。
<-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
# 根据 `关闭通道` 的思想,可以引出我们的下一个示例:遍历通道。