这段go代码有什么问题?


func main() {
    chan1 := make(chan struct{})
    chan2 := make(chan struct{})
    wg := &sync.WaitGroup{}
    wg.Add(2)
    go func() {
        defer wg.Done()
        for j := 0; j < 3; j++ {
             <-chan1
             fmt.Print("b", j)
             chan2 <- struct{}{}
        }
    }()

    go func() {
        defer wg.Done()
        for i := 0; i < 3; i++ {
             <-chan2
             fmt.Print("a",i)
             chan1 <- struct{}{}
        }
    }()

    chan1 <- struct{}{}
    wg.Wait()
    close(chan1)
    close(chan2)
}

死锁了。两个chan都是无缓冲的,chan1写入了四次数据,读取了三次。第一个goroutine会正常退出,但是第二个goroutine在最后一次写入chan1时,没有其他goroutine读chan1,因此第二个goroutine不会退出,而main goroutine又在等他退出,所以就死锁了。

第一个goroutine里在等待接收chan1里的数据后才能继续往chan2里写数据,
而第二个goroutine里在等待接收chan2里的数据后才能往继续chan1里写数据。
互相等待,直接就死锁了。