登录
首页 >  Golang >  Go问答

澄清 Golang 中无缓冲通道和容量为 1 的缓冲通道之间的区别

来源:stackoverflow

时间:2024-03-25 14:45:34 286浏览 收藏

在 Go 中,无缓冲通道(容量为 0)与容量为 1 的缓冲通道之间存在差异。当发送者和接收者都准备就绪时,无缓冲通道才能进行通信。这意味着一个协程正在执行接收操作,另一个协程正在执行发送操作,且操作顺序无关紧要。相反,缓冲通道允许发送者在没有接收者的情况下发送数据,而容量为 1 的缓冲通道只能容纳一个未接收的数据。

问题内容

在下面的链接中,关于 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 中无缓冲通道和容量为 1 的缓冲通道之间的区别》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

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