多生产者---多消费者问题(PV操作的简单例题)

2023-05-16

多生产者—多消费者问题(PV操作的简单例题)

在引入生产者消费者问题前,先要介绍几个知识点
1.临界区的相关问题。临界区是指每个进程访问临界资源的那段程序。临界资源是指每次只允许一个进程的访问的资源
2.PV操作,是一种利用信号量,通过while循环来控制进程的执行,以规避进程进入死锁状态

对于多生产者多消费者问题来说,其实最根本的和单生产者单消费者问题差不多
以下面这个例子来说明
■桌子上有一个盘子,每次只能放一个水果。爸爸专门向盘子中放苹果,妈妈专门放桔子,儿子等着吃盘中的桔子,女儿等着吃苹果。用P、V操作实现他们之间的同步。

Semaphore mutex=1,apple=0,orange=0, empty=1;Begin
  Parbegin
    Father: begin
     Repeat
     准备苹果
     Wait(empty);      在确认盘中是否为空,若empty不为0,则可继续执行下面
     Wait(mutex);      在确认其他进程是否在执行,若没有,则减一,开始后续操作
     放入苹果;          生产者行为
     Signal(mutex);    释放生产者动作,允许其他进程执行
     Signal(apple);    生产者行为成功,给apple库存加一,允许后续消费apple进程执行
    Until false;
   end
**********************************************************************
    Daughter:begin
     Repeat
     Wait(apple);      判断apple是否有有库存,若apple为0,则持续等待,否则减一并执行后续功能
     Wait(mutex);      判断是否有其他进程正在执行,若有,持续等待
     拿走苹果;          消费者行为
     Signal(mutex);    释放资源,允许其他进程进入临界区
     signal(empty);    释放资源,允许生产者进程进入临界区
    Until false;
   end
**********************************************************************
  Parbegin
    Mother: begin
     Repeat
     准备橘子
     Wait(empty);    判断盘子是否为空,empty为1则执行下一步
     Wait(mutex);    判断当前是否有进程占用临界区
     放入橘子;        生产者行为
     Signal(mutex);  释放资源,允许其他进程进入临界区
     Signal(orange); 释放资源,允许消费者进程进入临界区
    Until false;
   end
**********************************************************************
    Son:begin
     Repeat
     Wait(orange);    判断orange是否有有库存,若orange为0,则持续等待,否则减一并执行后续功能
     Wait(mutex);     判断是否有其他进程正在执行,若有,持续等待
     拿走橘子;         消费者行为
     Signal(mutex);   释放资源,允许其他进程进入临界区
     signal(empty);   释放资源,允许生产者进程进入临界区
    Until false;
   end

多生产者多消费者问题和单生产者单消费者问题本质上是差不多的。
生产者与消费者公用一个信号量来限制使用临界区资源
不同的消费者与不同的生产者对各自的产品与消费对象都用一个独立的信号量来控制,避免空等和错误使用

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

多生产者---多消费者问题(PV操作的简单例题) 的相关文章

  • 一文讲透java日志框架

    在项目开发过程中 xff0c 有一个必不可少的环节就是记录日志 xff0c 相信只要是个程序员都用过 xff0c 可是咱们自问下 xff0c 用了这么多年的日志框架 xff0c 你确定自己真弄懂了日志框架的来龙去脉嘛 xff1f 下面笔者就
  • HashMap底层原理

    在我们实际的项目中 xff0c HashMap这个集合类经常被用到 xff0c 可是就是这么一个常用的集合类 xff0c 却往往成了咱们面试中的绊脚石 即便你是个初级程序员 xff0c 也常会让你谈谈HashMap的底层原理 xff0c 今
  • 聊聊ThreadPoolExecutor线程池

    ThreadPoolExecutor是线程的池化技术 xff0c 也就是首先创建几个线程 xff0c 然后把线程放到池子里 xff0c 有任务来的时候直接从线程池中拉线程来执行任务 为什么要用池化技术 xff1f java中的线程是系统级别
  • Spring框架系列之bean的生命周期底层原理06

    bean的生命周期 xff0c 咱们必须从 AnnotationConfigApplicationContext的getBean方法开始 xff0c getBean顾名思义就是从Spring容器中得到一个Bean的实例对象 xff0c Sp
  • 电信运营商移动互联网发展分析

    电信运营商移动互联网发展分析 移动互联网是通信业发展的大趋势 xff0c 随着3G 和WiMAX 等高速无线接入技术的飞速发展 xff0c 移动互联网不仅继承固定互联网的很多技术 xff0c 并且在商务 娱乐以及移动性等方面拓展用户需求 自
  • Spring框架系列之bean的生命周期底层原理07

    上一篇我们预留了两个大的内容 xff0c 一个是Object sharedInstance 61 getSingleton beanName 从单例池中获取数据 xff0c 另外一个是getSingleton方法创建单例Bean xff0c
  • Spring框架系列之bean的生命周期底层原理08

    接着上一篇 xff0c 咱们继续doCreateBean方法的分析 xff0c doCreateBean内容比较多 xff0c 我们这次主要是把它的整体流程说下 xff0c 后续会逐个来分析每一个关键点 代码如下 xff1a protect
  • 2020-09-25 Python基础学习第三天笔记

    文章目录 一 可变字符串二 运算符三 列表1 列表的创建2 列表常用命令3 多维列表 四 元组 2020 9 24 Day3 一 可变字符串 需要原地修改字符串 xff0c 可以使用 io StringIO 对象或 array 模块 spa
  • Python Cookbook学习总结

    第一章 xff1a 数据结构和算法 任何序列 xff08 可迭代的对象 xff09 都可以通过一个简单的赋值操作来分解为单独的变量 xff0c 唯一的要求是变量的总数和结构要与序列相吻合 xff08 比如对于存储二维坐标等的二维数组 xff
  • SpringBoot解析yml/yaml/properties配置文件的四种方式汇总

    目录 一 配置文件注入方式一 64 Value 二 配置文件注入方式二 64 ConfigurationProperties 三 自定义解析类 xff0c 直接暴力读取yml配置文件 四 Spring配置文件的解析类Environment获
  • Linux下配置Apache为多端口 (centos7)

    apache设置多个不同的端口 xff0c 映射不同的文件 一 xff1a vim etc httpd conf httpd conf 查看http配置文件 滑倒最底部 xff0c 箭头标注的位置 我们需要进入该目录编辑 二 xff1a c
  • android11.0上通过广播屏蔽电源键功能

    framework base services core java com android server policy PhoneWindowManager java import java util HashSet import java
  • python和matlab实现随机攻击网络节点+蓄意攻击网络节点,实现最大连通子图比例、网络效率变化、平均距离变化等等。

    首先要有自己的邻接关系 xff0c 最好是邻接表 xff0c 如下图这样包括起点和终点 要在网络中读取自己的文件 xff0c 生成自己的复杂网络图 知道攻击方式包括哪些 xff1a 比如度 介数等 xff0c 选择自己想要的攻击方式 在研究
  • 2021-05-22

    第一个作业 xff1a 使用python编写一个数学表达式 注意 43 的运算顺序 xff0c 可以使用括号改变运算顺序 xff0c 和数学运算一样 第二个作业 xff1a 使用输入函数input xff08 提示符 xff09 xff0c
  • JavaScript变量的命名规则和命名规范

    变量的命名规则和命名规范 1 规则 你必须遵守 不然报错 1 1 一个变量只能由 数字 0 9 字母 a zA Z 美元符 划线下 组成 1 2 一个变量不能由 数字 开头 1 3 再 JS 中严格区分大小写 61 gt num Num N
  • 不惧掉签 | 苹果IPA安装包,免费自签教程

    最近连续更新了好几款 TikTok xff0c 基本上是刚更新没两天就掉签 大家也知道 xff0c 苹果的软件不像安卓 未上架App Store的软件只能签名后才能正常安装 不过 xff0c 好在国民手机管理软件 爱思助手 客户端也加入了
  • JavaScript把其他数据类型转换成字符串类型

    数据类型转换 转字符串 把其他数据类型转换成字符串类型 1 String 43 语法 String 你要转换的数据 43 返回值 转换好的数据 43 特点 61 gt 任何数据类型都能转换 2 toString 43 语法 你要转换的数据
  • JavaScript条件分支语句-switch语句

    条件分支语句 switch 43 语法 switch 要判断的变量 case 情况1 情况1执行的代码 break case 情况2 情况2执行的代码 break default 所有条件都不满足的时候执行的代码 43 注意 1 我们的每一
  • JavaScirpt - arguments

    arguments 43 在函数内部天生自带的变量 43 表示所有实参的集合 伪数组 arguments 的属性 1 length 61 gt 表示长度 arguments 里面由多少个数据 61 gt 其实就是你的函数调用由多少个实参 6
  • 简版弹幕实现。HTML+CSS+JAVASCRIPT

    思路 xff1a 1 设置video 2 设置输入框 3 获取输入框的内容 xff0c 添加 删除和更新 4 里面运用了单厂模式 xff0c 每次生成的例子都是一样的 span class token doctype lt DOCTYPE

随机推荐

  • webpack 模块加载原理

    webpack webpack 原理 1 webpack 模块加载原理 文件信息来源 xff1a webpack 深入理解模块加载原理 webpack 是一个模块打包器 xff0c 在它看来 xff0c 每一个文件都是一个模块 1 1 Co
  • 使用 FSL 和 TrackVis 分析 DTI 数据

    转载原文 使用 FSL 和 TrackVis 分析 DTI 数据 Alex 2018 05 21 free learner 64 163 com 弥散加权成像 xff08 Diffusion Weighted Imaging DWI xff
  • Java Swing界面设计UI(全)

    原文链接 http blog csdn net xietansheng article details 72814531 Java Swing GUI 图形界面窗口开发基础教程 xff0c 本教程将系统性地详细介绍 Java Swing 开
  • IntelliJ IDEA必会的几个常用设置

    IDEA 全称 IntelliJ IDEA xff0c 是java编程语言开发的集成环境 IntelliJ在业界被公认为最好的java开发工具 xff0c 以下归纳了初学者使用idea的一些常用设置 一 ctrl 43 滚轮调整页面大小 F
  • 什么是面向对象,它的三个基本特征:封装、继承、多态

    什么是面向对象思想 xff1f 已经学完了java确不知道如何跟别人解释面向对象是什么意思这很常见 让我们一起来回顾下这个奇思妙想 文章目录 一 面向对象与面向过程1 什么是面向过程 xff1f 2 什么是面向对象 xff1f 二 类与对象
  • 一篇文章说清 :无锁、偏向锁、轻量级锁、重量级锁

    文章目录 前言一 无锁二 偏向锁三 轻量级锁 xff08 自选锁 xff09 四 重量级锁锁升级场景 前言 JDK1 6为了减少获得锁和释放锁所带来的性能消耗 xff0c 引入了 偏向锁 和 轻量级锁 xff0c 所以在JDK1 6里锁一共
  • Spring EL正则表达式示例

    Spring EL使用简单的关键字 matches 支持正则表达式 xff0c 这真是太棒了 xff01 举些例子 xff0c 64 Value 34 39 100 39 matches 39 d 43 39 34 private bool
  • 数据库难点:脏读、幻读、不可重复读与四种隔离级别

    目录 前言一 什么是事务 xff1f 二 事务的ACID特性 xff08 1 xff09 原子性 xff08 2 xff09 一致性 xff08 3 xff09 隔离性 xff08 4 xff09 持久性 三 何为脏读 xff0c 幻读 x
  • java如何实现对Excel内容读写,如何将Excel内容导入导出数据库,让我们一起来看看

    文章目录 前言一 什么是POI xff1f 二 引入依赖三 用POI读取Excel文件内容四 用POI向Excel文件写入五 从Excel读取内容写入数据库六 从数据库读取内容写入Excel表中 前言 最近遇到这样一个需求 xff1a 需要
  • 安装Android Studio报错“gradle project sync failed“或“Cannot resolve symbol“的解决办法

    项目场景 xff1a 安装android studio 2020 3 1 26 windows 问题描述 1 34 gradle project sync failed 34 如图所示错误 2 但是接下来就遇到了 Cannot resolv
  • Centos7安装、各种环境配置和常见bug解决方案,保姆级教程(更新中)

    文章目录 前言一 Centos7安装二 各种环境配置与安装2 1 安装net tools xff08 建议 xff09 2 2 配置静态网络 xff08 建议 xff09 2 1 修改Centos7的时间 xff08 建议 xff09 2
  • 软件设计师提纲+复习资料整理(上午题)

    文章目录 软件设计师考试大纲上午题 xff08 选择题 xff09 一 计算机组成原理考点 xff1a CPU结构组成考点 xff1a 原码 反码 补码定点整数范围考点 xff1a 浮点数表示考点 xff1a RISC和CISC计算机的区别
  • idea控制台拖出来了,怎么恢复,解决办法

    问题描述 idea控制台拖出来了如何恢复成原样 解决方案 xff1a 方法一 方法二
  • MariaDB的安装与配置

    MariaDB的安装与配置 菜鸡我是用阿里源安装的 MariaDB是MySQL的一个分支 xff0c 由开源社区维护 xff0c 采用GPL授权许可 完全兼容MySQL 1 安装相对应的源 span class token function
  • 程序员如何更好的提升自己

    首先你得明白 xff0c 一个人的能力就像一个池塘 xff0c 不断的输入又不断地输出 xff0c 水池的容量以及水的质量决定了输出的高效与否 xff0c 输入大于输出 xff0c 你的池塘就会不断扩大 xff0c 换句话说你会的技能就越来
  • Linux find命令详解

    find命令 xff1a 快速查找数据信息 find 查找范围 条件01 a 条件02 a 条件03 根据多个多个条件查找数据 xff08 多个条件是并且关系 xff09 find 查找范围 条件01 o 条件02 o 条件03 根据多个多
  • TIME_WAIT过多故障,如何解决?

    1 time wait的作用 1 xff09 可靠地实现TCP全双工连接的终止 在进行关闭连接四次挥手协议时 xff0c 最后的ACK是由主动关闭端发出的 xff0c 如果这个最终的ACK丢失 xff0c 服务器将重发最终的FIN xff0
  • 作业管理-----操作系统

    浅谈作业管理 摘要 作业的概念及作业的提交方式 xff1a 作业是用户在一次解题或事务处理过程中要求计算机所作工作的集合 一个作业进入系统到运行结束 xff0c 一般要经历 后备 执行 完成 三种状态 为了管理和调度作业 xff0c 系统为
  • python network

    call the sync function after 2 seconds t 61 threading Timer 2 self sync t start 为什么TCP传输需要编码 send can not send a string
  • 多生产者---多消费者问题(PV操作的简单例题)

    多生产者 多消费者问题 xff08 PV操作的简单例题 xff09 在引入生产者消费者问题前 xff0c 先要介绍几个知识点 1 临界区的相关问题 临界区是指每个进程访问临界资源的那段程序 临界资源是指每次只允许一个进程的访问的资源 2 P