真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯網站制作重慶分公司

go語言中make(chanint,1)和make(chanint)的區(qū)別是什么

這篇文章主要介紹了go語言中make(chan int, 1)和make (chan int) 的區(qū)別是什么,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

創(chuàng)新互聯是一家專注于成都網站制作、網站建設與策劃設計,峨邊彝族網站建設哪家好?創(chuàng)新互聯做網站,專注于網站建設10多年,網設計領域的專業(yè)建站公司;建站業(yè)務涵蓋:峨邊彝族等地區(qū)。峨邊彝族做網站價格咨詢:13518219792

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

經過查資料:

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

無緩沖區(qū)channel

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

ch := make(chan int) // 創(chuàng)建無緩沖channel

go func() {
  fmt.Println("time sleep 5 second...")
  time.Sleep(5 * time.Second)
  <-ch
}()
h
fmt.Println("即將阻塞...")
ch <-1  // 協程將會阻塞,等待數據被讀取
fmt.Println("ch 數據被消費,主協程退出")

有緩沖區(qū)channel

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

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

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

感謝你能夠認真閱讀完這篇文章,希望小編分享的“go語言中make(chan int, 1)和make (chan int) 的區(qū)別是什么”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯,關注創(chuàng)新互聯行業(yè)資訊頻道,更多相關知識等著你來學習!


當前標題:go語言中make(chanint,1)和make(chanint)的區(qū)別是什么
分享路徑:http://weahome.cn/article/jjsiee.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部