zoukankan      html  css  js  c++  java
  • 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 对其解锁,可以有效地避免死锁

     加锁和解锁应该成对出现

  • 相关阅读:
    读后感之—寒门学子重要选择-程序员
    架构中的分而治之
    如何从码农进化到项目管理者
    饿了么架构
    简单理解支付宝和蚂蚁花呗的架构
    架构小谈之美团外卖
    漫谈架构总结之1500
    平台基本信息项目目标文档
    第六学期每周总结-第三周
    质量管理之可用性战术分析
  • 原文地址:https://www.cnblogs.com/ithubb/p/14701867.html
Copyright © 2011-2022 走看看