golang的channel阻塞例子分享

在这段 Go 代码中,确实会发生阻塞,以下是详细的解释:

func main() {
    ch := make(chan int, 1)

    go func() {
        // 这里接收数据并打印
        value := <-ch
        fmt.Println("Received:", value)
        value = <-ch
        fmt.Println("Received:", value)
    }()

    // 主 goroutine 发送数据
    ch <- 1

    fmt.Println("123456")
}

代码执行流程:

  1. 创建了一个带缓冲区的通道 ch,缓冲区大小为 1。
  2. 创建了一个新的 goroutine,在这个 goroutine 内部,有两次从 ch 通道接收数据的操作。
  3. 主 goroutine 通过 ch <- 1 向通道发送了一个值 1
  4. 主 goroutine 然后打印 "123456"

阻塞分析:

  • ch <- 1 发送操作会将值 1 发送到 ch 通道。由于 ch 是一个带缓冲的通道,并且缓冲大小为 1,所以第一次发送值 1 不会阻塞,它会直接被存入通道。

  • 在子 goroutine 中,value := <-ch 这行代码会从通道中接收一个值,成功接收后打印 "Received: 1"

  • 子 goroutine 接下来要执行 value = <-ch,但此时通道中已经没有值了,通道也没有关闭,因此这个接收操作会阻塞,等待下一个值被发送到通道中。

打印顺序:

  • 在主 goroutine 中,ch <- 1 发送成功后,主 goroutine 会继续执行 fmt.Println("123456")

  • 因为主 goroutine 和子 goroutine 是并发执行的,主 goroutine 不会被子 goroutine 的阻塞所影响,所以 "123456" 会被正常打印。

结论:

  • value = <-ch 会被阻塞,因为通道没有更多的数据可以接收。
  • "123456" 会被打印,因为主 goroutine 不会因为子 goroutine 的阻塞而被阻塞。
  • 4
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值