清華尹成帶你實戰GO案例(21)Go 並行通道Channel

尹成發表於2018-05-22
Go 並行通道Channel
Channel是連線並行協程(goroutine)的通道。你可以向一個通道寫入資料然後從另外一個通道讀取資料。
package main
import "fmt"
func main() {
// 使用`make(chan 資料型別)`來建立一個Channel
// Channel的型別就是它們所傳遞的資料的型別
messages := make(chan string)
// 使用`channel <-`語法來向一個Channel寫入資料
// 這裡我們從一個新的協程向messages通道寫入資料ping
go func() { messages <- "ping" }()
// 使用`<-channel`語法來從Channel讀取資料
// 這裡我們從main函式所在的協程來讀取剛剛寫入
// messages通道的資料
msg := <-messages
fmt.Println(msg)
}


執行結果
ping
當我們執行程式的時候,資料ping成功地從一個協程傳遞到了另外一個協程。
預設情況下,協程之間的通訊是同步的,也就是說資料的傳送端和接收端必須配對使用。Channel的這種
特點使得我們可以不用在程式結尾新增額外的程式碼也能夠獲取協程傳送端發來的資訊。因為程式執行到

msg:=<-messages 的時候被阻塞了,直到獲得傳送端發來的資訊才繼續執行




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



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

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

尹成學院微信:備註:CSDN



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



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

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

尹成學院微信:備註:CSDN

相關文章