亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

去渠道準備

去渠道準備

Go
Helenr 2023-06-19 15:53:50
我想了解 Go 中的頻道。我讀過默認情況下發送和接收塊,直到發送方和接收方都準備好。但是我們如何確定發送方和接收方的準備情況。例如在下面的代碼中package mainimport "fmt"func main() {    ch := make(chan int)    ch <- 1    fmt.Println(<-ch)}該程序將卡在通道發送操作上,永遠等待有人讀取值。即使我們在 println 語句中有一個接收操作,它也會以死鎖結束。但是對于下面的程序package mainimport "fmt"func main() {    ch := make(chan int)    go func () {        ch <- 1    }()    fmt.Println(<-ch)}整數從 go 例程成功傳遞到主程序。是什么讓這個計劃奏效?為什么第二個有效但第一個無效?go routine 會造成一些差異嗎?
查看完整描述

2 回答

?
LEATH

TA貢獻1936條經驗 獲得超7個贊

讓我們逐步完成第一個程序:


// My notes here

ch := make(chan int)  // make a new int channel

ch <- 1               // block until we can send to that channel

                      // keep blocking

                      // keep blocking

                      // still waiting for a receiver

                      // no reason to stop blocking yet...


// this line is never reached, because it blocks above forever.

fmt.Println(<-ch)

第二個程序將發送拆分到它自己的執行行中,所以現在我們有:


ch := make(chan int)  // make a new int channel


go func () {          // start a new line of execution

    ch <- 1           // block this second execution thread until we can send to that channel

}()


fmt.Println(<-ch)     // block the main line of execution until we can read from that channel

由于這兩條執行線可以獨立工作,因此主線可以下到通道fmt.Println并嘗試從通道接收。第二個線程將等待發送直到發送完畢。


查看完整回答
反對 回復 2023-06-19
?
九州編程

TA貢獻1785條經驗 獲得超4個贊

go 例程絕對有所作為。寫入通道的 go 例程將被阻塞,直到您的主函數準備好從 print 語句中的通道讀取。有兩個并發線程,一個讀取,一個寫入,滿足雙方的準備工作。

在您的第一個示例中,單個線程被通道寫入語句阻塞,并且永遠不會到達通道讀取。

您需要有一個并發的 go 例程,以便在您寫入通道時從通道中讀取。并發與通道使用密切相關。


查看完整回答
反對 回復 2023-06-19
  • 2 回答
  • 0 關注
  • 142 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號