net/rpc 为 Go 语言中 .Call 和 .Go 方法的区别是什么?
来源:stackoverflow
时间:2024-03-03 17:06:26 250浏览 收藏
来到golang学习网的大家,相信都是编程学习爱好者,希望在这里学习Golang相关编程知识。下面本篇文章就来带大家聊聊《net/rpc 为 Go 语言中 .Call 和 .Go 方法的区别是什么?》,介绍一下,希望对大家的知识积累有所帮助,助力实战开发!
我刚刚开始使用 golang 和 net/rpc 包。我试图了解什么时候可以使用异步 client.go() 调用而不是大多数在线示例使用的 client.call() 方法。会通过类似
的方式异步调用 client.callgo client.Call(...)
本质上与使用 client.go 调用相同?我也在网上看到过这个例子(例如调用多个并发 rpc 时)。
解决方案
go 异步调用该函数。它返回表示调用的 call 结构。当调用完成时,done 通道将通过返回相同的 call 对象发出信号。如果done为nil,go将分配一个新的通道。如果非 nil,done 必须被缓冲,否则 go 会故意崩溃。
这意味着它发出命令,但不等待它完成。
通过contrast:
call 调用指定函数,等待其完成,然后返回其错误状态。
这两种方法都不会直接在 goroutine 中执行*——这留给调用者作为练习(因此可能有人认为 go
是用词不当)。
如果你看看source to 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,因为这是一个非阻塞操作。
今天关于《net/rpc 为 Go 语言中 .Call 和 .Go 方法的区别是什么?》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!
-
502 收藏
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
139 收藏
-
204 收藏
-
325 收藏
-
477 收藏
-
486 收藏
-
439 收藏
-
357 收藏
-
352 收藏
-
101 收藏
-
440 收藏
-
212 收藏
-
143 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习