首页 > 后端开发 > Golang > 正文

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

PHPz
发布: 2024-02-14 10:15:09
转载
546 人浏览过

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

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

问题内容

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

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

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

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

这是否意味着在 ch <- "C" (如果容量 = 3)下面编写的任何代码仍然会运行?回到我最初关于容量 0 与 1 之间差异的问题,这是否意味着发送者下面的任何代码都不会运行(对于容量 = 0)?另一方面,如果capacity = 1,即使满容量为1,发送方下面的代码仍然会运行这么长时间?

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 的缓冲通道之间的差异的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:stackoverflow.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板