news 2026/4/16 15:49:01

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
实战:用信号量与环形缓冲区实现生产者-消费者模型

各类资料学习下载合集
链接: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
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 3:39:36

并行途径和并行性等级

一、资源共享 vs 时间重叠 vs 资源重复的区别这三个是计算机体系结构中提高硬件利用率的三种基本方法&#xff1a;方法核心思想硬件成本例子本质时间重叠同一套硬件&#xff0c;分时服务不同任务&#xff08;在时间上错开使用&#xff09;低&#xff08;一套设备&#xff09;CP…

作者头像 李华
网站建设 2026/4/16 15:08:22

HLS设计总结(一)

一、gcd(a,b)算法使用rtl和hls实现有何种区别ap_uint<32> gcd(ap_uint<32> opA,ap_uint<32> opB){#pragma HLS INLINEwhile(opA ! opB){ #pragma HLS PIPELINEif(opA > opB)opA opA - opB;elseopB opB - opA; }return opA; }二、如何写hls代码 1.top fu…

作者头像 李华
网站建设 2026/4/16 8:43:47

Linly-Talker在大学校园迎新系统的数字化应用

Linly-Talker在大学校园迎新系统的数字化应用系统架构与核心价值重塑 在每年九月的高校迎新季&#xff0c;成千上万的新生涌入校园&#xff0c;面对陌生环境、复杂流程和海量信息&#xff0c;他们常常手足无措。而负责接待的辅导员和志愿者也往往疲于奔命——重复解答相同问题、…

作者头像 李华
网站建设 2026/4/15 21:04:07

Linly-Talker与追一科技大模型平台集成测试

Linly-Talker与追一科技大模型平台集成测试 在金融客服、在线教育和电商直播等场景中&#xff0c;企业对“能听、会说、有表情”的智能数字人需求正以前所未有的速度增长。然而&#xff0c;大多数现有系统仍停留在预设脚本播放阶段——看似流畅的对话背后&#xff0c;缺乏真正的…

作者头像 李华
网站建设 2026/4/16 10:19:20

34、Windows Server 2008 性能监控全解析

Windows Server 2008 性能监控全解析 性能监控概述 性能优化策略的第一步是准确且持续地测量性能。监控网络和系统利用率等因素,能让你深入了解系统状况,这对评估更改效果极为有用。性能监控的整体流程通常包含以下步骤: 1. 建立当前性能基线。 2. 识别瓶颈。 3. 规划并…

作者头像 李华
网站建设 2026/4/16 10:21:36

Linly-Talker与云知声大模型技术对接实测

Linly-Talker与云知声大模型技术对接实测 在虚拟主播直播间里&#xff0c;一个面容逼真的数字人正流畅地回答观众提问&#xff1a;“这款产品的优惠活动将持续到本月底。”她的口型与语音精准同步&#xff0c;语气自然&#xff0c;甚至在说到“优惠”时还微微扬起嘴角&#xff…

作者头像 李华