登录
首页 >  Golang >  Go问答

除了通道,还有哪些可用于goroutine之间相互通信的方法?

来源:stackoverflow

时间:2024-02-09 21:15:21 159浏览 收藏

本篇文章向大家介绍《除了通道,还有哪些可用于goroutine之间相互通信的方法?》,主要包括,具有一定的参考价值,需要的朋友可以参考一下。

问题内容

我今天接受了面试,面试官给我带来的有趣的事情之一是我们知道 Channels 是 goroutine 相互通信的媒介。

但是,如果他们没有频道怎么办..!或者不想使用通道,是否有其他替代方法可以向 golang 中的 goroutine 发送和读取消息?

如果是,怎么会这样?


正确答案


通道不是并发或并行实体之间的第一个也不是唯一的通信工具。还有很多其他的。

作为一个讽刺性的例子,一个 goroutine 可以将包含消息的文件上传到 Amazon S3,而另一个 goroutine 可以获取该文件。这是一次沟通。

更有效的方法是创建消息并将其写入其他 goroutine 可以读取的本地文件。

另一种可能是通过一个 goroutine 打开服务器套接字,并从另一个 goroutine 连接到该套接字。并且您有一个全双工“通道”。

为了留在“地球”上,更简单、更有效的解决方案是通过共享变量发送消息,但对它的访问当然必须通过同步原语(例如 syncsync/atomic 包中的同步原语)进行同步。

一个(消息)切片可以由 2 个 Goroutine 共享,当第一个 Goroutine 想要向另一个 Goroutine 发送消息时,它可能会获取写锁(sync.RWMutex),将消息附加到切片,然后释放该切片锁。第二个 goroutine 可以使用读锁来检查切片是否有消息(长度 > 0),然后使用写锁从切片中获取消息(并将其删除)。

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>