自学嵌入式day33,互斥和同步

线程控制:互斥与同步

互斥(Mutex)

概念

在多线程环境中,互斥用于保证对临界资源 (如全局变量、文件、设备)的排他性访问 。当多个线程并发执行时(如 th1th2 交替运行),对共享资源的非原子操作(如 a++ 对应的多步汇编指令)可能导致数据不一致。互斥锁通过将临界区代码封装为原子操作(一次线程调度中必须完整执行),确保同一时刻仅有一个线程访问资源。

使用步骤

  1. 定义互斥锁

    c 复制代码
    pthread_mutex_t mutex;
  2. 初始化锁

    c 复制代码
    int pthread_mutex_init(pthread_mutex_t *mutex, const pthread_mutexattr_t *attr);
    • attr 通常设为 NULL(默认属性)。
    • 返回值:成功返回 0,失败返回非零值。
  3. 加锁

    c 复制代码
    int pthread_mutex_lock(pthread_mutex_t *mutex);
    • 若锁已被占用,则阻塞当前线程。
    • 临界区代码需短小,避免耗时操作或休眠。
  4. 解锁

    c 复制代码
    int pthread_mutex_unlock(pthread_mutex_t *mutex);
  5. 销毁锁

    c 复制代码
    int pthread_mutex_destroy(pthread_mutex_t *mutex);

同步(Semaphore)

概念

同步是互斥的扩展,用于控制线程执行的先后顺序。与互斥锁不同:

  • 互斥锁:加锁和解锁由同一线程完成。
  • 信号量 :线程可交叉释放资源(如 th1 释放 th2 的资源)。
  • 计数信号量 :初值可大于 1(如资源池),支持多线程并发访问。

使用步骤

  1. 定义信号量

    c 复制代码
    sem_t sem;
  2. 初始化信号量

    c 复制代码
    int sem_init(sem_t *sem, int pshared, unsigned int value);
    • pshared=0:线程间共享;pshared≠0:进程间共享。
    • value:初始资源数(如二值信号量设为 1)。
  3. P/V 操作

    • P 操作(申请资源)

      c 复制代码
      int sem_wait(sem_t *sem); // 资源不足时阻塞
    • V 操作(释放资源)

      c 复制代码
      int sem_post(sem_t *sem); // 释放后信号量值 +1
  4. 销毁信号量

    c 复制代码
    int sem_destroy(sem_t *sem);

死锁

产生条件

死锁由以下四个必要条件同时满足导致:

  1. 互斥条件:资源仅能被一个线程占用。
  2. 请求与保持:线程阻塞时仍持有已获取的资源。
  3. 不可剥夺:资源在使用完前不能被强制释放。
  4. 循环等待:线程间形成环形资源依赖链。

预防策略

  • 破坏任一条件即可避免死锁,例如:
    • 按固定顺序申请锁。
    • 设置锁超时机制。

互斥 vs. 信号量
特性 互斥锁 信号量
资源数量 单一资源 可多资源(计数信号量)
加解锁主体 同一线程 可跨线程交叉释放
适用场景 短临界区 允许休眠或耗时操作

相关推荐
好好学习天天向上~~2 小时前
6_Linux学习总结_自动化构建
linux·学习·自动化
冉佳驹3 小时前
Linux ——— 静态库和动态库的设计与使用
linux·动态库·静态库·fpic
陌上花开缓缓归以3 小时前
linux mtd-utils使用源码分析(ubuntu测试版)
linux·arm开发·ubuntu
wangjialelele3 小时前
Linux下的IO操作以及ext系列文件系统
linux·运维·服务器·c语言·c++·个人开发
HypoxiaDream4 小时前
LINUX-Ext系列⽂件系统
linux·运维·服务器
小毛驴8504 小时前
Linux curl 命令用法
linux·运维·chrome
李斯啦果4 小时前
【Linux】Linux目录配置
linux·运维·服务器
AI+程序员在路上4 小时前
linux下线程中pthread_detach与pthread_join区别
linux·运维·服务器
代码游侠4 小时前
C语言核心概念复习——C语言基础阶段
linux·开发语言·c++·学习
logocode_li4 小时前
说透 Linux Shell:命令与语法的底层执行逻辑
linux·运维·ssh