我剛剛開始使用 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,因為這是一個非阻塞操作。
- 1 回答
- 0 關注
- 176 瀏覽
添加回答
舉報
0/150
提交
取消