返回顶部
首页 > 资讯 > 后端开发 > GO >需要进一步澄清 Golang 中无缓冲通道(即容量 0)与容量 1 的缓冲通道之间的差异
  • 422
分享到

需要进一步澄清 Golang 中无缓冲通道(即容量 0)与容量 1 的缓冲通道之间的差异

2024-02-14 10:02:47 422人浏览 独家记忆
摘要

PHP小编香蕉需要进一步澄清golang中无缓冲通道(容量为0)与容量为1的缓冲通道之间的差异。在Golang中,通道是一种用于协程之间通信的重要机制,而无缓冲通道和缓冲通道则是通道的

PHP小编香蕉需要进一步澄清golang中无缓冲通道(容量为0)与容量为1的缓冲通道之间的差异。在Golang中,通道是一种用于协程之间通信的重要机制,而无缓冲通道和缓冲通道则是通道的两种类型。无缓冲通道要求发送方和接收方同时准备好,以实现同步通信,而缓冲通道允许发送方发送数据到通道中,即使接收方尚未准备好接收。进一步了解这两种通道类型的差异,有助于更好地理解和运用Golang中的通道机制。

问题内容

在下面的链接中,关于 1 容量的无缓冲通道与缓冲通道之间的差异给出的答复之一是,如果“通道是无缓冲的(容量为零),则仅当发送方和接收方时通信才会成功都准备好了”

当作者说发送者和接收者都准备好了时,这到底是什么意思?从时间顺序来看,我说一个必须先于另一个,这样说对吗?如果是这样,我说接收者必须先于发送者先准备好,这也对吗?

golang中通道缓冲区容量0和1的区别

我一直在尝试在官方和非官方渠道上寻找解释。然而,我还没有找到满意的答案。我最接近的是下面的解释。

这是否意味着在 ch

https://www.golinuxcloud.com/golang-buffered-channel/

谢谢!

解决方法

当作者说发送者和接收者都准备好了时,这到底意味着什么?

这意味着一个 goroutine 正在执行 receive,另一个 goroutine 正在执行 send。哪个 goroutine 首先开始操作并不重要。

换句话来说,发送 goroutine 会阻塞,直到另一个 goroutine 在通道上接收数据。

将此与具有可用容量的缓冲通道进行对比。一个 goroutine 可以完成向通道的发送,而无需等待另一个 goroutine 在通道上接收。

下面的示例说明了无缓冲通道和缓冲通道之间的区别。

sleepRecv := func(c chan int) {
    time.Sleep(time.Second)
    <-c
}

b0 := make(chan int, 0)
go sleepRecv(b0)
start := time.Now()
b0 <- 0                        // must wait for recv in goroutine
fmt.Println(time.Since(start)) // prints 1s

b1 := make(chan int, 1)
go sleepRecv(b1)
start = time.Now()
b1 <- 0                        // does not wait for recv in goroutine
fmt.Println(time.Since(start)) // prints 0s

以上就是需要进一步澄清 Golang 中无缓冲通道(即容量 0)与容量 1 的缓冲通道之间的差异的详细内容,更多请关注编程网其它相关文章!

您可能感兴趣的文档:

--结束END--

本文标题: 需要进一步澄清 Golang 中无缓冲通道(即容量 0)与容量 1 的缓冲通道之间的差异

本文链接: https://lsjlt.com/news/564390.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作