golang中为何在同一个goroutine中使用无缓冲通道会导致死锁

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
package main
 
import "fmt"
 
func main() {
    /*
    以下程序会导致死锁
    c := make(chan int)
    c <- 10
    n1 := <-c
    fmt.Println(n1)
    为什么在同一个goroutine中使用无缓冲通道会导致死锁?
    原因:1. 如果通道无缓冲区,则发送方会阻塞,直到接收方接收到该值
         2. 如果通道有缓冲区,则发送方会阻塞到值被复制到缓冲区,然后解堵塞,
            如果缓冲区已满,则会阻塞到其它goroutine从通道缓冲区中取走一个数据,然后再将值复制到缓冲区,最后解堵塞
    */
    // 以下程序就可以正常执行,main goroutine负责从无缓冲通道中接收数据,子goroutine负责往通道中写入数据
    c := make(chan int)
    go func() {
        for i := 0; i < 10; i++ {
            c <- i * 10
        }
        close(c)  // 关闭通道
    }()
    // 使用此方法必须关闭通道
    for i := range c {
        fmt.Println(i)
    }
    /* 使用此方法可以比关闭通道
    for i := 0; i < 10; i++ {
        fmt.Println(<-c)
    }
    */
}

  

posted @   专职  阅读(168)  评论(0编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)
点击右上角即可分享
微信分享提示