卓越飞翔博客卓越飞翔博客

卓越飞翔 - 您值得收藏的技术分享站
技术文章35631本站已运行398

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

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

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
卓越飞翔博客
上一篇: Go import Path 在版本化包中如何工作
下一篇: 返回列表
留言与评论(共有 0 条评论)
   
验证码:
隐藏边栏