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

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

net/rpc .Call 與 .Go 之間有什么區別?

net/rpc .Call 與 .Go 之間有什么區別?

Go
嗶嗶one 2023-05-15 14:40:30
我剛剛開始使用 Golang 和 net/rpc 包。我試圖了解您何時可以使用異步 client.Go() 調用大多數在線示例使用的 client.Call() 方法。會通過類似的方式異步調用 client.Callgo client.Call(...)本質上和使用 client.Go 調用是一樣的嗎?我也在網上看到過這個例子(例如當同時調用多個 RPC 時)。
查看完整描述

1 回答

?
函數式編程

TA貢獻1807條經驗 獲得超9個贊

記錄在案:

Go 異步調用該函數。它返回表示調用的 Call 結構。done 通道將在調用完成時通過返回相同的 Call 對象發出信號。如果 done 為 nil,Go 將分配一個新頻道。如果非零,則 done 必須被緩沖,否則 Go 會故意崩潰。


這意味著它發出命令,但不等待它完成。


相比之下:_


Call 調用命名函數,等待它完成,并返回它的錯誤狀態。


這兩種方法都不會直接在 goroutine 中執行*——這留給調用者作為練習(因此可能會提出一個用詞Go不當的論點)。


如果您查看源代碼Call,也許會更清楚:


func (client *Client) Call(serviceMethod string, args interface{}, reply?

interface{}) error {

? ? call := <-client.Go(serviceMethod, args, reply, make(chan *Call, 1)).Done

? ? return call.Error

}

所以實際上,Call是一個包裝器Go,它等待操作完成,而Go是底層函數,等待調用者。


*顯然,在后臺某處涉及一個goroutine,因為這是一個非阻塞操作。


查看完整回答
反對 回復 2023-05-15
  • 1 回答
  • 0 關注
  • 176 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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