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

实战:用信号量与环形缓冲区实现生产者-消费者模型

各类资料学习下载合集
链接:https://pan.quark.cn/s/770d9387db5f

在多线程编程中,生产者-消费者模型是处理数据流的核心模式。上一篇我们讲了“条件变量+互斥锁”的实现方式,今天我们来解锁一种更轻量级的武器——信号量(Semaphore),并结合环形队列来实现高效的数据吞吐。


一、 核心蓝图:双信号量控制

在这个模型中,我们不再关注“互斥锁”来保护整个链表,而是关注资源的数量。我们把固定大小的缓冲区看作两类资源:

  1. 空格子(Blank):供生产者存放数据。
  2. 产品(Product):供消费者提取数据。

1. 信号量定义

我们引入两个信号量:

  • blank_number:表示缓冲区中剩余的空闲位置数量。初始值为NUM(例如 5)。
  • product_number:表示缓冲区中已有的产品数量。初始值为0

2. 环形队列(Ring Buffer)

为了避免频繁的内存分配与释放(如链表节点),我们使用一个固定大小的全局数组queue[NUM]。通过取模运算i = (i + 1) % NUM,让数组下标首尾相接,形成一个环。


二、 生产者实现逻辑

生产者的任务是将数据填入空格子。它的逻辑可以概括为:“申请空格 -> 生产 -> 增加产品”

  1. 等待空格 (sem_wait(&blank_number))
    • blank_number减 1。
    • 如果blank_number为 0(说明缓冲区满了),生产者自动阻塞,等待消费者腾出位置。
  2. 生产产品
    • 将数据写入数组当前位置queue[p]
    • 移动下标p = (p + 1) % NUM
  3. 增加产品 (sem_post(&product_number))
    • product_number加 1。
    • 唤醒可能正在等待产品的消费者。

三、 消费者实现逻辑

消费者的任务是取走产品并腾出空间。它的逻辑概括为:“申请产品 -> 消费 -> 增加空格”

  1. 等待产品 (sem_wait(&product_number))
    • product_number减 1。
    • 如果product_number为 0(说明缓冲区空了),消费者自动阻塞,等待生产者产出。
  2. 消费产品
    • 读取数组当前位置queue[c]的数据。
    • 移动下标c = (c + 1) % NUM
    • (可选)将原位置清零queue[c] = 0,模拟消费动作。
  3. 增加空格 (sem_post(&blank_number))
    • blank_number加 1。
    • 唤醒可能正在等待空格的生产者。

四、 完整代码实现

下面的代码展示了如何使用semaphore.h实现上述逻辑。我们定义缓冲区大小为 5。

#include<stdio.h>#include<stdlib.h>#include<unistd.h>#include<pthread.h>#include<semaphore.h>#include
http://www.cnnetsun.cn/news/169107.html

相关文章:

  • 面对复杂业务,XinServer 给了我技术自信
  • 如何评估Linly-Talker生成视频的真实感?主观测评方法
  • 15、Windows Server DHCP 安装、授权与管理全解析
  • 渗透测试策略覆盖不全 后来才知道用强化学习动态生成攻击路径
  • Linly-Talker模型更新日志:v2.1版本新增五大功能
  • Linly-Talker能否接入企业微信/钉钉?API对接说明
  • 64、Windows 8 TCP/IP网络配置与故障排除指南
  • Linly-Talker支持动态光照渲染,视觉质感再升级
  • 数字人社交机器人:Linly-Talker在陪伴经济中的价值
  • 20、Azure Table 服务:实体操作、分页与序列化详解
  • Linly-Talker如何优化长段落无标点文本的断句策略?
  • Linly-Talker实战教程:如何用AI生成会说话的数字人
  • 46、掌握企业项目管理:从模板构建到资源配置
  • 57、掌握项目管理利器:全面解析项目规划与执行技巧
  • 31、深入解析IIS管理脚本与数据库操作
  • 常见快捷键
  • Linly-Talker支持多种肖像输入格式:证件照、自拍、动漫均可
  • 智慧城市之城市环境智能监管 非法倾倒行为自动识别 环保执法证据采 垃圾倾倒倾倒物品类型识别数据据 垃圾堆识别数据集 公路垃圾识别10315期
  • Chromium143原生支持HLS
  • 玩轮胎仿真不上手?老司机带你飙车。今天咱们用ABAQUS搞点硬核操作,从过盈充气到滚动传涵,手把手教你怎么让虚拟轮胎活起来
  • 当风电遇上“太极推手“:混合储能如何化解功率波动
  • MIPI DSI DPHY FPGA工程源码:Artix7-100t彩条驱动1024*600像...
  • 最近在折腾四旋翼导航时踩了不少坑,发现真正让无人机听话飞行的核心都在代码细节里。今天就拿手头正在调试的飞控项目举例,聊聊怎么用代码让四旋翼实现基础导航
  • 永磁同步电机全速域无传感器控制探索
  • Linly-Talker生成视频的镜头拉近推远动态效果实现
  • SpringBoot+Vue +线上教育培训办公系统管理平台源码【适合毕设/课设/学习】Java+MySQL
  • 36、Windows Server 2008 网络中的打印与网络策略服务介绍
  • 44、深入解析Windows Server 2008的安全保障与管理监控
  • 【python | pytorch | scipy】scipy scikit-learn库相互依赖?
  • 【python| pytorch】卸载py库,手动法