当前位置: 首页>>编程语言>>正文


Go语言教程:通道的关闭

返回Go语言教程首页

概念简介

关闭一个通道意味着不能再向这个通道发送值了。这个特性可以用来给这个通道的接收方传达工作已经完成的信息。

例程代码


package main

import "fmt"

// 在这个例子中,我们将使用一个 `jobs` 通道来传递 `main()` 中 Go
// 协程任务执行的结束信息到一个工作 Go 协程中。当我们没有多余的
// 任务给这个工作 Go 协程时,我们将 `close` 这个 `jobs` 通道。
func main() {
    jobs := make(chan int, 5)
    done := make(chan bool)

    // 这是工作 Go 协程。使用 `j, more := <- jobs` 循环的从
    // `jobs` 接收数据。在接收的这个特殊的二值形式的值中,
    // 如果 `jobs` 已经关闭了,并且通道中所有的值都已经接收
    // 完毕,那么 `more` 的值将是 `false`。当我们完成所有
    // 的任务时,将使用这个特性通过 `done` 通道去进行通知。
    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

# 通过关闭通道的学习,也让下面学习通道遍历水到渠成。

课程导航

学习上一篇:Go语言教程:非阻塞通道操作    学习下一篇:Go语言教程:通道遍历

相关资料

本例程github源代码:https://github.com/xg-wang/gobyexample/tree/master/examples/closing-channels

Go语言通道的关闭

本文由《纯净天空》出品。文章地址: https://vimsky.com/article/4056.html,未经允许,请勿转载。