当前位置: 首页 > ds >正文

互斥锁与同步锁

1. 锁的本质:解决并发问题的基石

在多线程/多进程环境中,临界区(Critical Section) 是访问共享资源的代码段。锁的核心目标是确保互斥访问——任意时刻仅有一个执行单元能进入临界区。

// 典型临界区示例
pthread_mutex_lock(&mutex); 
balance = balance + 100;  // 共享变量操作
pthread_mutex_unlock(&mutex);
2. 硬件级支持:原子指令的魔力

锁的底层依赖硬件提供的原子操作

  • TSL(Test and Set Lock)
    原子性地读取内存值并设置为新值(通常为1)
    enter_region:TSL REG, LOCK     ; 复制LOCK值到REG,同时设置LOCK=1CMP REG, #0       ; 检查原LOCK值JNE enter_region  ; 非0则循环等待RET
    
  • XCHG(Exchange)
    原子交换寄存器与内存内容(现代CPU更常用)
  • CAS(Compare and Swap)
    条件式原子交换(解决ABA问题)

⚠️ 硬件通过锁定内存总线确保原子性,但需注意:

  • 单核CPU可用屏蔽中断实现原子性
  • 多核系统必须依赖原子指令
3. 互斥锁(Mutex)的实现层级
3.1 用户空间锁(如自旋锁)
  • 适用场景:临界区极短(纳秒级)
  • 原理:忙等待(Busy Waiting)
  • 缺陷:CPU空转浪费资源
    // 基于原子指令的自旋锁
    void spin_lock(int *lock) {while (__sync_lock_test_and_set(lock, 1));
    }
    
3.2 内核辅助锁(如Futex)
  • 混合架构:用户态快速路径 + 内核态慢速路径
  • Linux Futex工作流程
    1. 尝试原子操作获取锁(用户态)
    2. 若失败则调用futex(FUTEX_WAIT)陷入内核
    3. 锁释放时通过futex(FUTEX_WAKE)唤醒等待者
  • 优势:无竞争时无需系统调用
3.3 内核级锁(如pthread_mutex)
pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
pthread_mutex_lock(&mutex);    // 可能触发系统调用
/* 临界区操作 */
pthread_mutex_unlock(&mutex);
  • 内核行为
    • 锁空闲时直接获取
    • 锁占用时线程进入睡眠态,释放CPU
4. 同步锁的经典范式:生产者-消费者模型
sem_t empty = N;  // 空缓冲区数量
sem_t full = 0;   // 已填充缓冲区数量
pthread_mutex_t mutex; // 缓冲区互斥锁// 生产者
void producer() {sem_wait(&empty);      // 等待空位pthread_mutex_lock(&mutex);insert_item(data);     // 安全写入pthread_mutex_unlock(&mutex);sem_post(&full);       // 增加资源计数
}// 消费者
void consumer() {sem_wait(&full);       // 等待数据pthread_mutex_lock(&mutex);data = remove_item();  // 安全取出pthread_mutex_unlock(&mutex);sem_post(&empty);      // 增加空位
}

关键点

  • 互斥锁(mutex)保护共享缓冲区
  • 信号量(semaphore)协调生产/消费节奏

    1

5. 锁的致命陷阱与规避策略
5.1 死锁(Deadlock)
  • 条件:互斥、持有等待、不可抢占、循环等待
  • 解决方案
    • 锁排序(Lock Ordering)
    • 超时机制(pthread_mutex_trylock
    • 死锁检测算法(银行家算法)
5.2 优先级反转(Priority Inversion)
  • 场景:低优先级线程持有锁,阻塞高优先级线程
  • 解决方案
    • 优先级继承(Linux的PTHREAD_PRIO_INHERIT
    • 优先级天花板(PTHREAD_PRIO_PROTECT
http://www.xdnf.cn/news/15547.html

相关文章:

  • SAP-ABAP:SAP库存管理核心增强:IF_EX_MB_DOCUMENT_BADI 深度解析
  • AI驱动编程范式革命:传统开发与智能开发的全维度对比分析
  • 【人工智能】通过 Dify 构建聊天助手
  • 【t检验】用奶茶店排队案例解释
  • LangChain 和 Dify 是什么
  • 基于51单片机的贪吃蛇游戏Protues仿真设计
  • 数据分类分级和重要数据标准解读
  • 文献查找任务及其方法
  • 当前(2024-07-14)视频插帧(VFI)方向的 SOTA 基本被三篇顶会工作占据,按“精度-速度-感知质量”三条线总结如下,供你快速定位最新范式
  • 计算机毕业设计Java轩辕购物商城管理系统 基于 SpringBoot 的轩辕电商商城管理系统 Java 轩辕购物平台管理系统设计与实现
  • 如何解决pip安装报错ModuleNotFoundError: No module named ‘collections’问题
  • 来时路,零帧起手到Oracle大师
  • 大模型安全建设:破误区、识风险、筑防线20250714
  • 体验RAG GitHub/wow-rag
  • HTML 文本格式化标签
  • Redis7持久化
  • TextIn:大学生的文档全能助手,让学习效率飙升
  • 【JAVA】监听windows中鼠标侧面键的按钮按下事件
  • React之旅-06 Ref
  • 波兰无人机具身导航基准测试与最新进展!FlySearch:探索视觉语言模型的探索能力
  • python学智能算法(十八)|SVM基础概念-向量点积
  • 深入了解linux系统—— 进程信号的产生
  • 基于Snoic的音频对口型数字人
  • OPC数采服务器软件Takebishi为何比Kepware实施成本更低?
  • I/O 多路复用实现方式
  • kafka的部署
  • 第十二批深度合成算法备案情况
  • 分布式系统中设计临时节点授权的自动化安全审计
  • Codeforces Round 787 (Div. 3)(A,B,C,D,E,F,G)
  • NSSCTF Web 一点学习