同步互斥——考试问题

问题描述

把学生和监考老师都看作进程,学生有N人,教师1人。考场门口每次只能进出一个人,进考场原则是先来先进。当N个学生都进入考场后,教师才能发卷子。学生交卷后可以离开考场,教师要等收上来全部卷子并封装卷子后才能离开考场。
问:

  • 需要设置几个进程?
  • 用P,V操作解决上述问题的同步互斥关系。

分析

考场门口每次只能进出一个人

考场门口是共享资源。

当N个学生都进入考场后,教师才能发卷子
教师要等收上来全部卷子并封装卷子后才能离开考场

这是两个同步行为。

信号量设置

door = 1    //能否进出门口
mutex1 = 1
mutex2 = 1   //互斥信号量
sr = 0   //学生是否到齐
eb = 0    //考试开始
eo = 0     //考试结束

int num_stu = 0;
int num_paper = 0;

解答

/*学生进程*/
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 = 1;i <= N;i++)
    发卷子;
    V(eb);   //开始考试
    P(eo);   //等待考试结束
    封装;
    P(door);
    出门;
    V(door);
}

转载于:https://www.cnblogs.com/EIMadrigal/p/9248213.html

  • 3
    点赞
  • 32
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值