這篇文章主要介紹了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) 的區別是什么”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。