代码是这样的
package main
import (
"fmt"
"sync"
"time"
)
func main() {
c := sync.NewCond(&sync.Mutex{}) //1
queue := make([]interface{}, 0, 10) //2
removeFromQueue := func(delay time.Duration) {
time.Sleep(delay)
c.L.Lock() //8
queue = queue[1:] //9
fmt.Println("Removed from queue")
c.L.Unlock() //10
c.Signal() //11
}
for i := 0; i < 10; i++ {
c.L.Lock() //3
for len(queue) == 2 { //4
c.Wait() //5
}
fmt.Println("Adding to queue")
queue = append(queue, struct{}{})
go removeFromQueue(1 * time.Second) //6
c.L.Unlock() //7
}
}
代码来源摘自 :https://www.kancloud.cn/mutouzhang/go/596828
第
3
处 和 第8
处 都加了锁,该锁都来自条件锁 ‘c’ 中的L
,且L
是互斥锁Mutex
,从代码执行的顺序来看, 从
3
---7
之间 执行了6
,未释放锁之前
6
中 又加了8
这处锁,为什么没有出现死锁, 不可重入 又该怎么理解呢?