mutex 锁

重复解锁引起panic

mutex 结构

type Mutex struct {

state int32

sema uint32

}

Mutex.state 表示互斥锁的状态,比如是否被锁定

Mutex.sema 表示信号量,协程阻塞等待该信号量,解锁的协程释放信号量从而唤醒等待信号量的协程

Mutex.state  四种状态

Locked 表示Mutex 是否已经被锁定 0 没有 1 锁定

Woken 是否有协程被唤醒 0 没有 1 有协程被唤醒 正在加速过程中

Starving  是否处于饥饿状态 0 没有 1 饥饿状态 说明有协程阻塞超过了1ms

Waiter 阻塞等待协程的个数,协程解锁时根据此值来判断是否需要释放信号量。

 

2.

自旋过程

自旋好处 当加锁失败时不必立即转入阻塞,有一定机会获得锁,这样可避免协程切换。

满足自旋条件

  1.自旋次数要足够少 通常为4 ,自旋最多4次

  2. CPU核数要大于1

  3.协程调度机制中的Process 的数量要大于1

  4.协程调度机制中的可运行队列必须为空,否则会延迟协程调度

Mutex 模式

  Normal 模式 默认 满足自旋时可以

  Starving 模式 饥饿模式下不会启动 自旋

 3

 使用defer 避免死锁

 加锁后立即使用defer 对其解锁,可以有效地避免死锁

 加锁和解锁应该成对出现

上一篇:数据库事务的部分(前言)


下一篇:多线程编程(11) - 多线程同步之 Mutex (互斥对象)[续]