我是go的初学者,我今天写了一个问题代码。本意是让资源生成和消费的时候同时打印出该资源信息。
但是该程序会导致死锁,有没有什么解决方法能保证输出信息和管道同步
```go
var mu sync.Mutex
func produce(ch chan<- int){
for i:=0;i<10;i++{
mu.Lock()
ch<-i
fmt.Println("produce:"+strconv.Itoa(i))
mu.Unlock()
}
}
func consumer(ch <- chan int){
for i:=0;i<10;i++{
mu.Lock()
v:=<-ch
fmt.Println("consumer:"+strconv.Itoa(v))
mu.Unlock()
}
}
func main(){
ch:=make(chan int,5)
go produce(ch)
go consumer(ch)
time.Sleep(10*time.Second)
}
```
刚运行了一下,原因是正如3楼所说的,consumer(ch)早于produce(ch)先执行,
consumer(ch)上来先拿到mu.Lock然后立马阻塞在了v:=<-ch, 而produce(ch)执行的时候一直拿不到mu.Lock,所以导致produce(ch)无法生产, consumer(ch)干等着没什么可消费的。你把go consumer(ch) go produce(ch)顺序换一下就不一样了
#4
更多评论
个人理解不一定正确: produce在执行第五次的时候,ch已经执行mu.Lock(),此时ch已满,通道阻塞,但是mu.Unlocl没有释放锁,所以造成了持续阻塞。
#1