清華尹成帶你實戰GO案例(56)Go通道的同步功能

尹成發表於2018-05-22
Go通道的同步功能
我們使用通道來同步協程之間的執行。
下面的例子是通過獲取同步通道資料來阻塞程式執行的方法來等待另一個協程執行結束的。
也就是說main函式所在的協程在執行到
<-don
e 語句的時候將一直等待worker函式所在的協程執行完
成,向通道寫入資料才會(從通道獲得資料)繼續執行。
package main
import "fmt"
import "time"
// 這個worker函式將以協程的方式執行
// 通道`done`被用來通知另外一個協程這個worker函式已經執行完成
func worker(done chan bool) {
fmt.Print("working...")
time.Sleep(time.Second)
fmt.Println("done")
// 向通道傳送一個資料,表示worker函式已經執行完成
done <- true
}
func main() {
// 使用協程來呼叫worker函式,同時將通道`done`傳遞給協程
// 以使得協程可以通知別的協程自己已經執行完成
done := make(chan bool, 1)
go worker(done)
// 一直阻塞,直到從worker所在協程獲得一個worker執行完成的資料
<-done
}


執行結果

working...done
如果我們從main函式裡面移除
<-don

e 語句,那麼main函式在worker協程開始執行之前就結束了。




網址:http://www.qukuailianxueyuan.io/



欲領取造幣技術與全套虛擬機器資料

區塊鏈技術交流QQ群:756146052  備註:CSDN

尹成學院微信:備註:CSDN



網址:http://www.qukuailianxueyuan.io/



欲領取造幣技術與全套虛擬機器資料

區塊鏈技術交流QQ群:756146052  備註:CSDN

尹成學院微信:備註:CSDN

相關文章