TYUT太原理工大学2022操作系统大题之PV操作

2023-10-18 02:30

本文主要是介绍TYUT太原理工大学2022操作系统大题之PV操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题型一:PV操作

前言:该题题目中会给出我们一个任务(通常可以分几步完成,每一步为一个进程),要求我们用PV操作实现该任务的同步问题,类似于这样:

0ffe2de916c64b81a373eb60d11617f4.png

首先让我们用一个简单的例子(生产者-消费者问题)来理解PV操作:

一个生产者,一个消费者,公用一个缓冲区:

该任务可分为两个部分(也就是两个进程):进程1——生产者生产一个产品放入缓冲区;

进程2——消费者从缓冲区拿走产品进行消费。我们就是要用PV操作实现进程1、2的同步。

让我们来看一下完整的代码一:

begin                    //begin-end相当于{-}semaphore s1=1;      //表示缓冲区是否为空,初值为1semaphore s2=0;      //表示缓冲区中是否为满,初值为0cobegin              //cobegin与coend作用是确保P生产(进程)与P消费(进程)同步进行process P生产    //用process定义进程beginLs:              //Ls意味L生产,下文还有Lx表示L消费生产一个产品;     //此处中文必须写,用来解释pv操作p(s1);           //s1=s1-1=0,意味着放入了产品使缓冲区不为空产品送往缓冲区;   //此处中文必须写,用来解释pv操作v(s2);           //s2=s2+1=1,意味着取出了产品使缓冲区为空goto Ls;          //Ls和goto Ls并用相当与while(true){ },使用它是为了确保p、v两个操作成对存在,避免发生中断endprocess P消费beginLx:从缓冲区取出一个产品;p(s2);消费该产品;v(s1);goto Lx;  endcoend
end

我们还可以用代码二来代替代码一,如下:

semaphore s1=1;
semaphore s2=0;main()
{
cobegin
shengchan();
xiaofei();
coend
}shengchan()
{
while(true){             //while(true){ },使用它是为了确保p、v两个操作成对存在,避免发生中断生产一个产品;     //此处中文必须写,用来解释pv操作p(s1);           //s1=s1-1=0,意味着放入了产品使缓冲区不为空产品送往缓冲区;   //此处中文必须写,用来解释pv操作v(s2);     }
}xiaofei()
{
while(true){从缓冲区取出一个产品;p(s2);消费该产品;v(s1);}
}

考试时我们用代码一。

有了“生产者-消费者”的铺垫我们来看一下文章最开始的3道例题,加深理解

桌子上有一只盘子,每次只能放入一个水果。爸爸专向盘中放苹果,妈妈专向盘中放橘子,女儿专吃盘中的苹果,儿子专吃盘中的橘子。试用PV操作实现父、母、儿、女进程的同步。

begin semaphore S1=1;//(盘中是否为空)semaphore S2=0; //(盘中是否有苹果)semaphore S3=0; //(盘中是否有橘子)cobegin    process P父beginLf:取一个苹果;P(S1); 放入苹果;V(S2);goto Lf;end    process P母beginLm:取一个橘子;P(S1); 放入橘子;V(S3);goto Lm; endprocess P儿 beginLs:P(S3); 从盘中取橘子;V(S1);    吃橘子;goto Ls;endprocess P女beginLd:P(S2);从盘中取苹果;V(S1);吃苹果;goto Ld;endcoend
end

2eefac9aec744ef2a8ace011a8214756.png

 320522c0f62e429cb10a94e577fcabee.png

 软件2019届真题:

91a4c01c22e34f60853b5da18cbfc8d3.png

 谢谢“碧桃和露”5月22号打赏给我的8毛钱

谢谢“qq_52937762”5月23号打赏给我的1.6元

这篇关于TYUT太原理工大学2022操作系统大题之PV操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/229602

相关文章

python panda库从基础到高级操作分析

《pythonpanda库从基础到高级操作分析》本文介绍了Pandas库的核心功能,包括处理结构化数据的Series和DataFrame数据结构,数据读取、清洗、分组聚合、合并、时间序列分析及大数据... 目录1. Pandas 概述2. 基本操作:数据读取与查看3. 索引操作:精准定位数据4. Group

Python操作PDF文档的主流库使用指南

《Python操作PDF文档的主流库使用指南》PDF因其跨平台、格式固定的特性成为文档交换的标准,然而,由于其复杂的内部结构,程序化操作PDF一直是个挑战,本文主要为大家整理了Python操作PD... 目录一、 基础操作1.PyPDF2 (及其继任者 pypdf)2.PyMuPDF / fitz3.Fre

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali

MySQL 强制使用特定索引的操作

《MySQL强制使用特定索引的操作》MySQL可通过FORCEINDEX、USEINDEX等语法强制查询使用特定索引,但优化器可能不采纳,需结合EXPLAIN分析执行计划,避免性能下降,注意版本差异... 目录1. 使用FORCE INDEX语法2. 使用USE INDEX语法3. 使用IGNORE IND

Python使用openpyxl读取Excel的操作详解

《Python使用openpyxl读取Excel的操作详解》本文介绍了使用Python的openpyxl库进行Excel文件的创建、读写、数据操作、工作簿与工作表管理,包括创建工作簿、加载工作簿、操作... 目录1 概述1.1 图示1.2 安装第三方库2 工作簿 workbook2.1 创建:Workboo

Ubuntu 24.04启用root图形登录的操作流程

《Ubuntu24.04启用root图形登录的操作流程》Ubuntu默认禁用root账户的图形与SSH登录,这是为了安全,但在某些场景你可能需要直接用root登录GNOME桌面,本文以Ubuntu2... 目录一、前言二、准备工作三、设置 root 密码四、启用图形界面 root 登录1. 修改 GDM 配

JSONArray在Java中的应用操作实例

《JSONArray在Java中的应用操作实例》JSONArray是org.json库用于处理JSON数组的类,可将Java对象(Map/List)转换为JSON格式,提供增删改查等操作,适用于前后端... 目录1. jsONArray定义与功能1.1 JSONArray概念阐释1.1.1 什么是JSONA

Java操作Word文档的全面指南

《Java操作Word文档的全面指南》在Java开发中,操作Word文档是常见的业务需求,广泛应用于合同生成、报表输出、通知发布、法律文书生成、病历模板填写等场景,本文将全面介绍Java操作Word文... 目录简介段落页头与页脚页码表格图片批注文本框目录图表简介Word编程最重要的类是org.apach

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

mysql表操作与查询功能详解

《mysql表操作与查询功能详解》本文系统讲解MySQL表操作与查询,涵盖创建、修改、复制表语法,基本查询结构及WHERE、GROUPBY等子句,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随... 目录01.表的操作1.1表操作概览1.2创建表1.3修改表1.4复制表02.基本查询操作2.1 SE