操作系统PV编程题目总结一
1.今有一个文件F供进程共享,现把这些进程分为A、B两组,规定同组的进程可以同时读文件F;但当有A组(或B组)的进程在读文件F时就不允许B组(或A组)的进程读文件F。试用P、V操作(记录型信号量)来进行管理。
这是读者-写者问题变形,文件F在A与B之间要进行互斥,设信号量Fmutex用来两组间互斥,显然每组的读者要进行计数,来说明有木有某组在读文件,需要2个计数变量c1和c2,再设信号量Asem和Bsem分别对2个计数变量c1和c2进行互斥访问。
Semaphore Fmutex=1,Asem=0,Bsem=0;
int c1=c2=0;
Cobegin
Pa(i=1,2,3...){
P(Asem)
c1++;
if(c1==1)P(Fmutex)
V(Asem)
reading F;
P(Asem)
c1--;
if(c1==0)V(Fmutex)
V(Asem)
}
Pb(i=1,2,3...){
P(Bsem)
c2++;
if(c2==1)P(Fmutex)
V(Bsem)
reading F;
P(Bsem)
c2--;
if(c2==0)V(Fmutex)
V(Bsem)
}
coend
2.过双道十字路口问题。

这个问题是读者-写着问题的变形,路口要在水平和垂直方向上进行互斥,但在p1和p3方向上不需要互斥;同样p2和p4方向上也不需要互斥。因此可以设p1和p3为一组,p2和p4为一组。设信号量mutex用来两组间互斥。每组上来车要进行计数,需要2个计数变量c1和c2,再设信号量sem13和sem24分别对2个计数变量c1和c2进行互斥访问。
Semaphore mutex=1,sem13=1,sem24=1;
int c1=2=0;
cobegin
p1(){
P(sem13)
c1++;
if(c1=1) P(mutex)
V(sem13)
P1通过路口;
P(sem13)
c1--;
if(c1==0)V(mutex)
V(sem13)
}
p2(){
P(sem24)
c2++;
if(c2==1)P(mutex)
V(sem24)
P2通过路口;
P(sem24)
c2--;
if(c2==0)V(mutex)
V(sem24)
}
p3(){
P(sem13)
c1++;
if(c1=1) P(mutex)
V(sem13)
P3通过路口;
P(sem13)
c1--;
if(c1==0)V(mutex)
V(sem13)
}
p4(){
P(sem24)
c2++;
if(c2==1)P(mutex)
V(sem24)
P4通过路口;
P(sem24)
c2--;
if(c2==0)V(mutex)
V(sem24)
}
coend
3.吃水果问题:桌上有一只盘子,每次只能放一个水果,爸爸专向盘中放苹果,妈妈专向盘中放桔子,儿子专等吃盘里的桔子,女儿专等吃盘里的苹果。只要盘子空,则爸爸或妈妈可向盘中放水果,仅当盘中有自己需要的水果时,儿子或女儿可从中取出,请给出四人之间的同步关系,并用P、V操作实现四人正确活动的程序。
父亲和母亲先放水果,儿子女儿再取水果;父亲与女儿,母亲与儿子是一个同步关系,父亲与母亲要竞争空盘子,但空盘子容量为2.
设信号量m1表示盘子空位,信号量m2表示儿子是否能取苹果,m3表示女儿能否取桔子。
int m1=2,m2=0,m3=0;
cobegin
p1(){
while(1){
洗桔子;
P(m1);
放桔子;
V(m3);
}
}
p2(){
while(1){
洗苹果;
P(m1);
放苹果;
V(m2);
}
}
p3(){
while(1){
P(m2);
取苹果;
V(m1);
吃苹果;
}
}
p4(){
while(1){
P(m3);
取桔子;
V(m1);
吃桔子;
}
}
coend
4.试利用记录型信号量写出一个不会出现死锁的哲学家进餐问题的算法。
解法一:
semaphore Chopstick[5],5;
chopstick[0].value=chopstick[1].value=1;
chopstick[2].value=chopstick[3].value=1;
chopstick[4].value=1;
S.value=4;//最多允许4个哲学家同时拿筷子
process Pi()(i=0,1,2,3,4){//第i个哲学家进程
while(true){
wait(5);//看是否允许拿筷子
wait(chopstick[i]);//拿起左边筷子
wait(chopstick[(i+1)%5]);//拿起右边筷子
eating;
signal(chopstick[i]);//放下左边筷子
signal(chopstick[(i+1)%5]);//放下右边筷子
signal(5);
thinking;
}
}
parbegin//进程并发执行
P0();
P1();
P2();
P3();
P4();
parend
解法二:奇数号哲学家先拿左边筷子,然后再拿右边筷子;偶数号哲学家先拿右边筷子,然后再拿左边筷子。
semaphore chopstick[5];
chopstick[0].value=chopstick[1].value=1;
chopstick[2].value=chopstick[3].value=1;
chopstick[4].value=1;
parbegin
process Pi()(i=0,2,4){
while(true){
wait(chopstick[(i+1)%5]);
wait(chopstick[i]);
eating;
signal(chopstick[(i+1)%5]);
signal(chopstick[i]);
thinking;
}
}
process Pi()(i=1,2){
while(true){
wait(chopstick[i]);
wait(chopstick[i+1]);
eating;
signal(chopstick[i]);
signal(chopstick[i+1]);
thinking;
}
}
parend
5.假定阅览室最多可同时容纳100个人阅读,读者进入时,必须在阅览室门口的一个登记表上登记,内容包括姓名、座位号等,离开时要撤掉登记内容。用P、V操作描述读者进程的同步算法。
6.公共汽车上司机和售票员问题。
设公共汽车上,司机和售票员的活动分别是:
司机: 售票员:
启动车辆 上下乘客
正常行车 关车门
到站停车 售票
开车门
上下乘客
在汽车不断到站,停车,行驶过程中,这两个活动的同步关系。
7.和尚打水问题。某寺庙,有小和尚和老和尚若干,有一个水缸,由小和尚提水入缸供老和尚饮用。水缸可以容纳10桶水,水取自同一口井中,由于水井口窄,每次只能容纳一个水桶取水。水桶总数为3个。每次入水、取水仅为一桶,且不可同时进行。请用PV原语写出协调小和尚和老和尚动作的程序。
操作系统PV编程题目总结一的更多相关文章
- OJ——华为编程题目:输入字符串括号是否匹配
package t0815; /* * 华为编程题目:输入字符串括号是否匹配 * 若都匹配输出为0,否则为1 * 样例输入:Terminal user [name | number (1)] * 样例 ...
- php实现 提取不重复的整数(编程题目能够最快的熟悉函数)
php实现 提取不重复的整数(编程题目能够最快的熟悉函数) 一.总结 一句话总结:编程题目能够最快的熟悉函数. 1.字符串反转函数? 没有str_revserse,有arr_reverse,这里是st ...
- 网易云课堂_C++程序设计入门(下)_期末考试_期末考试在线编程题目
期末考试在线编程题目 返回考试 本次考试题目一共两个,在考试期间可以不限制次数地提交 温馨提示: 1.本次考试属于Online Judge题目,提交后由系统即时判分. 2.学生可以在考试截止时间 ...
- 小议 - 来自《XX时代XX公司》的笔试编程题目
经过几天的雾霾,魔都终于放晴了.哥投了几天的简历,希望找到一份.NET开发方面的岗位.也收到了几个面试邀请.这不应Ge老师的要求,选了个良辰吉日,带着身份证,学位证怀揣着2B青年的梦想来这个XX公司面 ...
- 关于C语言的几个考试编程题目
提交要求:1:邮件名称:学号后三位-题目编号-姓名-期中考试.例如:098-1-沈苗-期中考试2:不用附件提交,直接写邮件,内容包括编程思路(写一段自己对题目的认识.思路.技术细节等).源代码.运行结 ...
- 【编程题目】请修改 append 函数,利用这个函数实现两个非降序链表的并集
42.请修改 append 函数,利用这个函数实现(链表):两个非降序链表的并集,1->2->3 和 2->3->5 并为 1->2->3->5另外只能输出结 ...
- 【编程题目】栈的 push、pop 序列
29.栈的 push.pop 序列(栈)题目:输入两个整数序列.其中一个序列表示栈的 push 顺序,判断另一个序列有没有可能是对应的 pop 顺序.为了简单起见,我们假设 push 序列的任意两个整 ...
- 【编程题目】题目:定义 Fibonacci 数列 输入 n,用最快的方法求该数列的第 n 项。
第 19 题(数组.递归):题目:定义 Fibonacci 数列如下:/ 0 n=0f(n)= 1 n=1/ f(n-1)+f(n-2) n=2输入 n,用最快的方法求该数列的第 n 项. 思路:递归 ...
- 【编程题目】输入一个单向链表,输出该链表中倒数第 k 个结点
第 13 题(链表):题目:输入一个单向链表,输出该链表中倒数第 k 个结点.链表的倒数第 0 个结点为链表的尾指针.链表结点定义如下: struct ListNode {int m_nKey;Lis ...
随机推荐
- SQL SERVER服务器登录名、角色、数据库用户、角色、架构的关系
原创链接:https://www.cnblogs.com/junfly/articles/2798023.html SQL SERVER 基础教程中关于服务器登录名.服务器角色.数据库用户.数据库角色 ...
- Linux系统GNOME主题安装与Tweaks工具使用
需要软件: GNOME Tweaks--使主题修改更加容易一个工具 安装主题: 下载主题:mac themes下载链接:https://www.gnome-look.org/p/1241688/ 这里 ...
- word20161231
1. measurement 英[ˈmeʒəmənt]美[ˈmeʒərmənt]n. 量度; 份量,尺寸; 测量法; (量得的) 尺寸;[例句]We took lots of measurements ...
- 413 重温HTML + css 考试 + 访问HTML元素
考试前的复习 初学css1:认识CSS 1.1:css简介,css全称是层叠样式表,Cascading style sheets 1.2:css的作用,主要是用于定义html内容在浏览器内的显示样式, ...
- 论文阅读笔记(一)FCN
本文先对FCN的会议论文进行了粗略的翻译,使读者能够对论文的结构有个大概的了解(包括解决的问题是什么,提出了哪些方案,得到了什么结果).然后,给出了几篇博文的连接,对文中未铺开解释的或不易理解的内容作 ...
- 使用 “mini-css-extract-plugin” 提取css到单独的文件
一.前言 我们在使用webpack构建工具的时候,通过style-loader,可以把解析出来的css通过js插入内部样式表的方式到页面中,插入的结果如下: <style> .wrappe ...
- spring cloud 集群健康监控--turbine-dashboard仪表盘
这里仍然以Windows和jdk为运行环境,按照下面的步骤打包-运行-访问就能看到效果. 运维健康监控--hystrix-dashboard仪表盘 java -jar F:\jars-dashboar ...
- 利用C# 窗体设计 写一个抽奖游戏
老师布置了一个任务,要求我们做一个抽奖游戏,以下是我个人制作的一个作品与写项目的过程. 我们用到了8个pictureBox控件和一个button,设置好大小,并且编排成一个九宫个形状 添加窗体的背景图 ...
- TypeError: softmax() got an unexpected keyword argument 'axis'
出现这个问题,有几种解决办法,可以调低一下keras的版本,比如: pip install keras==2.1 不过还有个更方便的方法,从错误可知softmax中不包含axis这个参数,那么把axi ...
- 023_System Integrity Protection in macos
背景:之前写的在/usr/bin下的一个登陆线上脚本,由于使用timemachine还原了系统,发现怎么也修改不了,加sudo也不行. 后来查询才得知系统默认开启了"系统集成保护" ...