Process Synchronization-Example 1
2024-09-01 17:48:33
问题描述
把学生和监考老师都看作进程,学生有N人,教师1人。考场门口每次只能进出一个人,进考场原则是先来先进。当N个学生都进入考场后,教师才能发卷子。学生交卷后可以离开考场,教师要等收上来全部卷子并封装卷子后才能离开考场。
问:
- 需要设置几个进程?
- 用P,V操作解决上述问题的同步互斥关系。
分析
考场门口每次只能进出一个人
考场门口是共享资源。
当N个学生都进入考场后,教师才能发卷子
教师要等收上来全部卷子并封装卷子后才能离开考场
这是两个同步行为。
信号量设置
door = //能否进出门口
mutex1 =
mutex2 = //互斥信号量
sr = //学生是否到齐
eb = //考试开始
eo = //考试结束 int num_stu = ;
int num_paper = ;
解答
/*学生进程*/
void student()
{
P(door);
进门;
V(door);
P(mutex1); //增加学生人数
num_stu++;
if(num_stu == N)
V(sr);
V(mutex1);
P(eb); //等教师宣布开始考试
考试;
交卷;
P(mutex2); //增加试卷份数
num_paper++;
if(num_paper == N)
V(eo);
V(mutex2);
P(door);
出门;
V(door);
} /*教师进程*/
void teacher()
{
P(door);
进门;
V(door);
P(sr); //最后一个学生唤醒老师
for(i = ;i <= N;i++)
发卷子;
V(eb); //开始考试
P(eo); //等待考试结束
封装;
P(door);
出门;
V(door);
}
最新文章
- Net作业调度(二) -CrystalQuartz远程管理
- PHP 爬虫
- 热烈祝贺华清远见《ARM处理器开发详解》第2版正式出版
- sencha combobox下拉框不用jsonstore,直接使用字符串数组做数据源
- C语言 数组类型与数组指针类型
- Android tab导航的几种方法:ActionBar tab +fragment,Viewpager+pagerTitleStrip,开源框架ViewPageIndicator 和 ViewPager
- ACM题目————Subsequence
- SQL中SUBSTRING函数的用法
- Android Apps开发环境搭建
- CPU affinity 进程和线程的亲缘性
- ModelAndView解析
- c# 委托 delegate
- 【NOIP2006提高组】能量项链
- hdu 6068--Classic Quotation(kmp+DP)
- 使用keepalived使用主备热备份功能
- [Cpp] 面向对象程序设计 C++
- SQL高级查询基础
- 解决iPhone Safari 兼容性CSS背景显示不全问题
- Notes : <;Hands-on ML with Sklearn &; TF>; Chapter 5
- linux添加新硬盘
热门文章
- Hadoop(二)搭建Hadoop
- 按公式产生随机数、java中的重载、递归、有关计算机计算的问题
- wireshark抓包实战(七),数据流追踪
- JAVA中Calendar 类的应用
- 廖雪峰 Git 教程 + Git-Cheat-Sheet 学习总结
- 搞搞hibernate.current_session_context_class
- AJ学IOS 之微博项目实战(10)微博cell中图片的显示以及各种填充模式简介
- Android | 教你如何在安卓上实现通用卡证识别,一键各种卡绑定
- Mybatis Generator通用Join的实现
- 使用binlog2sql工具来恢复数据库