码农知识堂 - 1000bd
Python
PHP
JS/TS
JAVA
C/C++
C#
GO
Kotlin
Swift
消费者与生产者问题
生产消费者问题
1)问题描述
系统中有
一组生产者进程
和
一组消费者进程
,生产者进程每次
生产一个
产品放入缓冲区,消费者进程每次从缓冲区中
取出一个
产品并使用。(注: 这里的“产品”理解为某种数据)
生产者、消费者
共享
一个初始为空、大小为n的
缓冲区
。
只有缓冲区
没满
时,
生产者
才能把产品
放入
缓冲区,否则必须等待。
只有缓冲区
不空
时,
消费者
才能从中
取出
产品,否则必须等待。
缓冲区是临界资源,各进程必须
互斥
地访问。
问题分析
因为生产者与消费者 生产者与生产者 消费者与消费者 需要互斥的去访问缓冲区 所以设置互斥信号量 初值为1
生产者必须先消耗一个空缓冲区 完成后生产出一个产品
消费者必须先消耗一个产品 完成后产生一个空缓冲区
实现
实现互斥的P操作一定要在实现同步的P操作之后
因为如果互斥的P操作在同步的V操作之前,就可能产生死锁
尽量把非必须在临界区运行的代码在临界区外执行,尽快让出临界区,让其他进程使用
相关阅读:
计组 | 六七章 总线 IO输入输出系统 —— 总复习知识点回顾
迭代器 Iterator
WRF4.2安装过程全记录
【精算研究02/10】 风险的损失分布方法 (LDA)浅述
Cholesterol-PEG-Thiol CLS-PEG-SH 胆固醇-聚乙二醇-巯基
使用高斯Redis实现二级索引
阿里云服务器系统怎么选?Alibaba Cloud Linux操作系统介绍
Java中的集合框架
为什么大家会觉得考PMP没用?
使用QtWebApp搭建Http服务器
原文地址:https://blog.csdn.net/qq_50985215/article/details/127580055
最新文章
攻防演习之三天拿下官网站群
数据安全治理学习——前期安全规划和安全管理体系建设
企业安全 | 企业内一次钓鱼演练准备过程
内网渗透测试 | Kerberos协议及其部分攻击手法
0day的产生 | 不懂代码的"代码审计"
安装scrcpy-client模块av模块异常,环境问题解决方案
leetcode hot100【LeetCode 279. 完全平方数】java实现
OpenWrt下安装Mosquitto
AnatoMask论文汇总
【AI日记】24.11.01 LangChain、openai api和github copilot
热门文章
十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
奉劝各位学弟学妹们,该打造你的技术影响力了!
五年了,我在 CSDN 的两个一百万。
Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
面试官都震惊,你这网络基础可以啊!
你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
心情不好的时候,用 Python 画棵樱花树送给自己吧
通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
13 万字 C 语言从入门到精通保姆级教程2021 年版
10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系
2656653265@qq.com
京ICP备2022015340号-1
正则表达式工具
cron表达式工具
密码生成工具
京公网安备 11010502049817号