同步(Synchronization)和互斥(Mutual Exclusion)关系

同步(Synchronization)和互斥(Mutual Exclusion)是多线程/多进程编程中两个核心概念,它们的核心区别如下:


1. 定义与目标

  • 同步

    协调多个线程/进程的执行顺序,确保它们按预期顺序访问共享资源或协作完成任务。
    目标 :避免竞争条件(Race Condition),保证程序逻辑正确性。
    示例:线程A写入数据后,线程B才能读取。

  • 互斥

    保护共享资源在同一时刻仅被一个线程/进程访问,防止数据损坏。
    目标 :避免数据竞争(Data Race),保证资源访问的原子性。
    示例:线程A访问共享变量时,线程B必须等待。


2. 实现机制

  • 同步

    常用机制:

    • 信号量(Semaphore)
    • 条件变量(Condition Variable)
    • 事件(Event)
    • 屏障(Barrier)
      特点:可能涉及线程间的主动等待或通知。
  • 互斥

    常用机制:

    • 互斥锁(Mutex)
    • 自旋锁(Spinlock)
      特点:强制独占访问,其他线程必须阻塞或忙等。

3. 关键区别

维度 同步(Synchronization) 互斥(Mutual Exclusion)
核心目标 控制执行顺序 保护资源独占访问
典型场景 生产者-消费者模型、线程协作 共享变量修改、临界区保护
阻塞性质 可能主动等待(如条件变量) 强制阻塞(如互斥锁)
关系 同步可能依赖互斥(如先锁后同步) 互斥是同步的基础工具之一

4. 经典比喻

  • 互斥:像厕所的"占用"标志,一次只能一个人使用。
  • 同步:像接力赛的交接棒,必须等前一棒完成才能传递。

5. 代码示例(伪代码)

c 复制代码
// 互斥:保护共享变量
mutex_lock(&lock);
shared_var++;
mutex_unlock(&lock);

// 同步:线程A等待线程B完成
semaphore_wait(&sem); // 等待信号
// 执行后续操作

总结:互斥是同步的子集,但同步的范围更广(如线程协作、事件通知等)。实际开发中,两者常结合使用(例如用互斥锁保护临界区,再用条件变量实现线程等待)。

相关推荐
不能跑的代码不是好代码4 分钟前
STM32窗口看门狗(WWDG)知识点及标准库使用指南
stm32·单片机·嵌入式硬件
bingquan33335 分钟前
在 Ghidra 中分析STM32裸机固件
stm32·单片机·嵌入式硬件
羽获飞6 分钟前
从零开始学嵌入式之STM32——11.STM32---USART串行通讯
stm32·单片机·嵌入式硬件
宵时待雨2 小时前
STM32笔记归纳9:定时器
笔记·stm32·单片机·嵌入式硬件
逐步前行2 小时前
STM32_新建工程(寄存器版)
stm32·单片机·嵌入式硬件
bai5459363 小时前
STM32 CubeIDE 通过PWM占空比控制舵机角度
stm32·单片机·嵌入式硬件
简单中的复杂5 小时前
【避坑指南】RK3576 Linux SDK 编译:解决 Buildroot 卡死在 host-gcc-final 的终极方案
linux·嵌入式硬件
上海合宙LuatOS5 小时前
LuatOS核心库API——【audio 】
java·网络·单片机·嵌入式硬件·物联网·音视频·硬件工程
LS_learner6 小时前
Snapd和Apt—Linux 上两种完全不同的软件包管理系统
嵌入式硬件
点灯小铭6 小时前
基于51单片机的双档交流电压表设计与实现
单片机·嵌入式硬件·毕业设计·51单片机·课程设计·期末大作业