在 Effective Go 中,介绍了一种 goroutine 与 channel 搭配使用的方法。
package main import ( "fmt" "time" ) func main() { c := make(chan string) go func() { time.Sleep(1000) fmt.Println("Go first!") c <- "done" }() fmt.Println("Go after.") fmt.Println("No waiting.") <-c fmt.Println("Wait for the first one.") }
在这个示例中,使用 go func() {}() 相当于让一段代码在背景执行,我们不用等待它结束就可以继续执行下面的程序,因此,该程序的运行结果是最先打印 "Go after."
如果不使用 channel 那么将会在最后才打印 "Go first!"
这里使用了 channel, 当遇到 <-c 时,程序就会被阻塞,需要等待消息发过来才能继续执行。
即,在打印完 "No waiting." 之后,等待消息,打印 "Go first!", 发送消息("done"),收到消息,打印 "Wait for the first one."
也就是说,可以通过使用 channel 来监视 goroutine 有没有结束。