我们可以使用通道来同步 Go 协程间的执行状态。这里是一个使用阻塞的接受方式来等待一个 Go 协程的运行结束。

Example:

package main

import "fmt"
import "time"

//这是一个我们将要在 Go 协程中运行的函数。done 通道将被用于通知其他 Go 协程这个函数已经工作完毕。
func worker(done chan bool){
    fmt.Println("Working......")
    time.Sleep(time.Second)
    fmt.Println("done")

    //发送一个值来通知我们已经完工啦。
    done <- true
}

func main(){
    //使用 make(chan val-type) 创建一个新的通道。通道类型就是他们需要传递值的类型
    done := make(chan bool, 1)

    go worker(done)

    //程序将在接收到通道中 worker 发出的通知前一直阻塞。
    //如果你把 <- done 这行代码从程序中移除,程序甚至会在 worker还没开始运行时就结束了。
    <- done
}

Result:

$ go run example.go
Working......
done
12-30 21:19