1. 程式人生 > 程式設計 >詳解go語言 make(chan int, 1) 和 make (chan int) 的區別

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

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

經過查資料:

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

無緩衝區channel

用make(chan int) 建立的chan,是無緩衝區的,send 資料到chan 時,在沒有協程取出資料的情況下, 會阻塞當前協程的執行。ch <- 後面的程式碼就不會再執行,直到channel 的資料被接收,當前協程才會繼續往下執行。

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 傳送第一個資料,主協程不會退出。傳送第二個時候,緩衝區已經滿了, 此時阻塞主協程。

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) 的區別,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回覆大家的。在此也非常感謝大家對我們網站的支援!
如果你覺得本文對你有幫助,歡迎轉載,煩請註明出處,謝謝!