代码是这个样子的,我就是想用用并发的功能做个小样子,结果一直报错,报错信息见代码下方
package main
import (
"fmt"
"sync"
"time"
)
func main() {
var wg sync.WaitGroup
server := make(chan int)
for i := 0; i < 3; i++ {
time.Sleep(time.Second)
wg.Add(1)
go func(id int) {
fmt.Println("A Customer is Coming")
<-server
fmt.Println("A Customer is Being Served")
time.Sleep(2 * time.Second)
fmt.Println("Service is finished, the customer is leaving")
server <- 1
wg.Done()
}(i)
}
for i := 0; i < 2; i++ {
server <- 1
}
wg.Wait()
close(server)
fmt.Println("Over")
}
错误信息:fatal error: all goroutines are asleep - deadlock!
我解决我的问题了,是我在初始化channel的时候没有设置缓存量,所以当go func 和main一起操作channel时,就会死锁,好像是这么回事。
<- server这个我想表达的是有一个server接待了来的这个顾客。
谢谢你的回复
#2
更多评论
协程里面的```server<-1```去掉,然后第二个for循环的条件改成 ``` i < 3 ``` , 这段代码为什么会dead lock,因为 <-chan 或者 chan <- 都会阻塞,如果只有其中一个,那就会dead lock
#3