本文主要是介绍操作系统实验进程同步--读者优先,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
实习1:进程同步--读者优先
实习要求
在Windows 2000 环境下,创建一个包含n 个线程的控制台进程。用这n 个线程来表示n
个读者或写者。每个线程按相应测试数据文件的要求,进行读写操作。请用信号量机制分别
实现读者优先和写者优先的读者-写者问题。
读者-写者问题的读写操作限制:
1)写-写互斥;
2)读-写互斥;
3)读-读允许;
读者优先的附加限制:如果一个读者申请进行读操作时已有另一读者正在进行读操作,
则该读者可直接开始读操作。
写者优先的附加限制:如果一个读者申请进行读操作时已有另一写者在等待访问共享资
源,则该读者必须等到没有写者处于等待状态后才能开始读操作。
运行结果显示要求:要求在每个线程创建、发出读写操作申请、开始读写操作和结束读
写操作时分别显示一行提示信息,以确信所有处理都遵守相应的读写操作限制。
测试数据文件格式
测试数据文件包括n 行测试数据,分别描述创建的n 个线程是读者还是写者,以及读写
操作的开始时间和持续时间。每行测试数据包括四个字段,各字段间用空格分隔。第一字段
为一个正整数,表示线程序号。第二字段表示相应线程角色,R 表示读者是,W 表示写者。
第三字段为一个正数,表示读写操作的开始时间。线程创建后,延时相应时间(单位为秒)
后发出对共享资源的读写申请。第四字段为一个正数,表示读写操作的持续时间。当线程读
写申请成功后,开始对共享资源的读写操作,该操作持续相应时间后结束,并释放共享资源。
下面是一个测试数据文件的例子:
1 R 3 5
2 W 4 5
3 R 5 2
4 R 6 5
源代码如下:
/************************************************************************/
/* 操作系统实践-- 读者写者问题
/* 读者优先算法实现
/* 时间: 2004-12.10
/* 作者: 唐良
/************************************************************************/
#include <windows.h>
#include <ctype.h>
#include <stdio.h&g
这篇关于操作系统实验进程同步--读者优先的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!