Home > Backend Development > Golang > Does the behavior of a go channel change depending on how messages are sent to it?

Does the behavior of a go channel change depending on how messages are sent to it?

WBOY
Release: 2024-02-09 10:39:20
forward
791 people have browsed it

go 通道的行为是否会根据消息发送到它的方式而改变?

php editor Xiaoxin In the go language, a channel is a mechanism used to transfer data between goroutines. The behavior of a channel depends on how messages are sent to it. When a channel is declared buffered, the goroutine sending the message will put the message into the channel's buffer and then continue execution. When the channel is declared unbuffered, the goroutine sending the message will block until other goroutine receives the message from the channel. Therefore, it can be said that the behavior of a channel changes depending on how messages are sent to it.

Question content

Why do these two pieces of code execute differently?

  1. Running the following code will return a fatal error: all goroutines are sleeping - deadlock! error.
func main() {
    ch := make(chan int)
    ch <- 1
    fmt.println(<-ch)
}
Copy after login
  • Running the following code correctly will return 2 and 3 (one line each).
  • ch := make(chan int)
        go buffer(ch)
        fmt.Println(<-ch)
        fmt.Println(<-ch)
    }
    
    func buffer(ch chan int) {
        ch <- 2
        ch <- 3
    }
    Copy after login

    #1 will only execute correctly if ch is defined as a buffered channel. Why? Why does buffer() in ch accept 2 values ​​without complaining?

    Solution

    Send operations on unbuffered channels will block until another goroutine reads data from it. This is why the first piece of code deadlocks: when you send to the channel, no other goroutine reads from it.

    In the second case, you have a goroutine sending two values ​​to the channel, and the main goroutine reads from the channel twice while sending. The channel does not accept two sends, but one after the other, with the first send operation unblocked by the first read and the second send operation unblocked by the second read.

    The above is the detailed content of Does the behavior of a go channel change depending on how messages are sent to it?. For more information, please follow other related articles on the PHP Chinese website!

    Related labels:
    source:stackoverflow.com
    Statement of this Website
    The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
    Popular Tutorials
    More>
    Latest Downloads
    More>
    Web Effects
    Website Source Code
    Website Materials
    Front End Template