清華尹成帶你實戰GO案例(58)Go通道緩衝

尹成發表於2018-05-22
Go通道緩衝
預設情況下,通道是不帶緩衝區的。
傳送端傳送資料,同時必須又接收端相應的接收資料。
而帶緩衝區的通道則允許傳送端的資料傳送和接收端的資料獲取處於非同步狀態,就是說傳送端傳送的資料
可以放在緩衝區裡面,可以等待接收端去獲取資料,而不是立刻需要接收端去獲取資料。
不過由於緩衝區的大小是有限的,所以還是必須有接收端來接收資料的,否則緩衝區一滿,資料傳送端就
無法再傳送資料了。
package main
import "fmt"
func main() {
// 這裡我們定義了一個可以儲存字串型別的帶緩衝通道
// 緩衝區大小為2
messages := make(chan string, 2)
// 因為messages是帶緩衝的通道,我們可以同時傳送兩個資料
// 而不用立刻需要去同步讀取資料
messages <- "buffered"
messages <- "channel"
// 然後我們和上面例子一樣獲取這兩個資料
fmt.Println(<-messages)
fmt.Println(<-messages)
}


執行結果
buffered

channel




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



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

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

尹成學院微信:備註:CSDN



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



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

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

尹成學院微信:備註:CSDN

相關文章