GO语言Metex

Mutex互斥锁

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

Mutex正常模式:

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

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

Mutex饥饿模式:

直接加入等待队列FIFO

防止尾端延迟


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

在正常模式下

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

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

相关推荐
I Promise34几秒前
C++ 基础数据结构与 STL 容器详解
开发语言·数据结构·c++
morrisonwu3 分钟前
kafka4.2对应php rdkafka扩展安装以及php的producer和consumer写法及避坑
开发语言·php
Lyyaoo.6 分钟前
【JAVA基础面经】== 和 equals() 的区别
java·开发语言·jvm
报错小能手11 分钟前
ios开发方向——swift并发进阶核心 async/await 详解
开发语言·ios·swift
喵个咪12 分钟前
go-wind-cms 微服务架构设计:为什么基于 Kratos?
后端·微服务·cms
青花瓷16 分钟前
采用QT下MingW编译opencv4.8.1
开发语言·qt
神奇小汤圆18 分钟前
百度面试官:Redis 内存满了怎么办?你有想过吗?
后端
喵个咪19 分钟前
Headless 架构优势:内容与展示解耦,一套 API 打通全端生态
前端·后端·cms
开心就好202521 分钟前
HTTPS超文本传输安全协议全面解析与工作原理
后端·ios
小江的记录本23 分钟前
【JEECG Boot】 JEECG Boot——数据字典管理 系统性知识体系全解析
java·前端·spring boot·后端·spring·spring cloud·mybatis