系統城裝機大師 - 唯一官網:www.farandoo.com!

當前位置:首頁 > 腳本中心 > 其它 > 詳細頁面

詳解go語言 make(chan int, 1) 和 make (chan int) 的區別

時間:2020-02-20來源:系統城作者:電腦系統城

遇到golang channel 的一個問題:發現go 協程讀取channel 數據 并沒有按照預期進行協作執行。

經過查資料:

使用channel 操作不當導致,channel分 有緩沖區 和 無緩沖區 , 以下是兩者的區別。

無緩沖區channel

用make(chan int) 創建的chan, 是無緩沖區的, send 數據到chan 時,在沒有協程取出數據的情況下, 會阻塞當前協程的運行。ch <- 后面的代碼就不會再運行,直到channel 的數據被接收,當前協程才會繼續往下執行。

?
1
2
3
4
5
6
7
8
9
10
11
ch := make(chan int) // 創建無緩沖channel
 
go func() {
  fmt.Println("time sleep 5 second...")
  time.Sleep(5 * time.Second)
  <-ch
}()
h
fmt.Println("即將阻塞...")
ch <-1  // 協程將會阻塞,等待數據被讀取
fmt.Println("ch 數據被消費,主協程退出")

有緩沖區channel

channel 的緩沖區為1,向channel 發送第一個數據,主協程不會退出。發送第二個時候,緩沖區已經滿了, 此時阻塞主協程。

?
1
2
3
4
5
6
7
8
9
10
ch := make(chan int, 1) // 創建有緩沖channel
go func() {
  fmt.Println("time sleep 5 second...")
  time.Sleep(5 * time.Second)
  <-ch
}()
ch <-1  // 協程不會阻塞,等待數據被讀取
fmt.Println("第二次發送數據到channel, 即將阻塞")
ch <-1  // 第二次發送數據到channel, 在數據沒有被讀取之前,因為緩沖區滿了, 所以會阻塞主協程。
fmt.Println("ch 數據被消費,主協程退出")

總結: 在創建channel的時候, 要注意是否需要緩沖區。有緩沖區時:在不超過緩沖區大小時,不會出現 發送方阻塞. 無緩沖區時: 只要channel 數據沒有被拿走,始終會阻塞發送方。

以上所述是小編給大家介紹的詳解go語言 make(chan int, 1) 和 make (chan int) 的區別,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

分享到:

相關信息

系統教程欄目

欄目熱門教程

人氣教程排行

站長推薦

熱門系統下載

jlzzjlzz亚洲乱熟在线播放