问题描述

把学生和监考老师都看作进程,学生有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);
}

最新文章

  1. Net作业调度(二) -CrystalQuartz远程管理
  2. PHP 爬虫
  3. 热烈祝贺华清远见《ARM处理器开发详解》第2版正式出版
  4. sencha combobox下拉框不用jsonstore,直接使用字符串数组做数据源
  5. C语言 数组类型与数组指针类型
  6. Android tab导航的几种方法:ActionBar tab +fragment,Viewpager+pagerTitleStrip,开源框架ViewPageIndicator 和 ViewPager
  7. ACM题目————Subsequence
  8. SQL中SUBSTRING函数的用法
  9. Android Apps开发环境搭建
  10. CPU affinity 进程和线程的亲缘性
  11. ModelAndView解析
  12. c# 委托 delegate
  13. 【NOIP2006提高组】能量项链
  14. hdu 6068--Classic Quotation(kmp+DP)
  15. 使用keepalived使用主备热备份功能
  16. [Cpp] 面向对象程序设计 C++
  17. SQL高级查询基础
  18. 解决iPhone Safari 兼容性CSS背景显示不全问题
  19. Notes : &lt;Hands-on ML with Sklearn &amp; TF&gt; Chapter 5
  20. linux添加新硬盘

热门文章

  1. Hadoop(二)搭建Hadoop
  2. 按公式产生随机数、java中的重载、递归、有关计算机计算的问题
  3. wireshark抓包实战(七),数据流追踪
  4. JAVA中Calendar 类的应用
  5. 廖雪峰 Git 教程 + Git-Cheat-Sheet 学习总结
  6. 搞搞hibernate.current_session_context_class
  7. AJ学IOS 之微博项目实战(10)微博cell中图片的显示以及各种填充模式简介
  8. Android | 教你如何在安卓上实现通用卡证识别,一键各种卡绑定
  9. Mybatis Generator通用Join的实现
  10. 使用binlog2sql工具来恢复数据库