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中文网其他相关文章!