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里写数据。
互相等待,直接就死锁了。