GO语言Metex

Mutex互斥锁

Go 复制代码
type Mutex struct{
    state int32 // 0表示未加锁 1表示加锁,原子操作
    sema uint32 // 信号量,用作等待队列
}

Mutex正常模式:

尝试加锁的G会先自旋几次,若获不到锁,则加入等待队列. 正常模式下,自选和等待队列的一起竞争

因为G频繁的挂起和唤醒会导致开销,为了高吞吐

Mutex饥饿模式:

直接加入等待队列FIFO

防止尾端延迟


前面其他位表示多少个等待者

在正常模式下

自旋的条件,当单核下自旋没意义,或者只有一个P时自旋也没意义.

在多核下,,且至少有一个其他的P在running,且当前P的本地队列为空才可以自旋转.

相关推荐
咖啡八杯9 小时前
GoF设计模式——策略模式
java·后端·spring·设计模式
lizhongxuan10 小时前
AI Agent 上下文压缩利器 Headroom
后端
Csvn12 小时前
SSH 远程管理与安全加固 — 运维的守门之道
后端
IT_陈寒12 小时前
Python搞不定字符串编码?这破玩意坑我两小时!
前端·人工智能·后端
菜鸟谢13 小时前
Rust 智能指针完整详解
后端
菜鸟谢14 小时前
Rust 函数完整知识点详解
后端
爱勇宝14 小时前
淡泊名利之前,先承认我们都很焦虑
前端·后端·程序员
菜鸟谢14 小时前
Rust 闭包(Closure)完整详解
后端
ServBay14 小时前
如何利用本地技术栈构建 0 成本 AI SaaS 雏形
后端·aigc·ai编程
菜鸟谢14 小时前
Rust 集合 + 迭代器完整详解
后端