设计2 读者写者问题。
一、设计目的。
通过对操作系统内核实现**的阅读、修改、设计,理解和掌握复杂的操作系统的工作原理。理解进程及信号量的概念。
二、设计要求。
1、为每个读者/写者产生一个线程,设计正确的同步算法。
2、每个读者/写者对该存储区进行操作后,即时显示该存储区的全部内容、当前指针位置和读者/写者线程的自定义标识符。
3、读者应有3个以上,写者应有有两个以上。
4、多个读者/写者之间须共享对存储区进行操作的函数**。
三、设计说明。
所谓读者写着问题,是指保证一个writer进程必须与其他进程互斥地访问共享对象的同步问题。
读者写者问题可以这样的描述,有一群写者和一群读者,写者在写同一本书,读者也在读这本书,多个读者可以同时读这本书,但是,只能有一个写者在写书,并且,读者必写者优先,也就是说,读者和写者同时提出请求时,读者优先。当读者提出请求时需要有一个互斥操作,另外,需要有一个信号量s来当前是否可操作。
信号量机制是支持多道程序的并发操作系统设计中解决资源共享时进程间的同步与互斥的重要机制,而读者写者则是这一机制的一个经典范例。
主要设计流程图。
四、运行结果及分析。
测试数据文件包括n 行测试数据,分别描述创建的n 个线程是读者还是写者,以及读写操作的开始时间和持续时间。每行测试数据包括四个字段,各字段间用空格分隔。第一字段为一个正整数,表示线程序号。
第二字段表示相应线程角色,r 表示读者是,w 表示写者。第三字段为一个正数,表示读写操作的开始时间。线程创建后,延时相应时间(单位为秒)后发出对共享资源的读写申请。
第四字段为一个正数,表示读写操作的持续时间。当线程读写申请成功后,开始对共享资源的读写操作,该操作持续相应时间后结束,并释放共享资源。下面是一个测试数据文件的例子:
1, w,4, 5,
2, w, 16, 4,
3, r, 5, 2,
4, w, 6, 5,
5, r, 4, 3,在读者写者同时在队列中等待申请资时,读者优先调用资源。而且如果一个读者申请进行读操作时已有另一读者正在进行读操作,则该读者可直接开始读操作,即读读允许。进程1是w操作,在时间4时进入队列,运行时间是5,在它进入时没有进程占用资源,它既占用资源;直到它释放资源,等候的进程有3,4,5;
结束界面。五、总结。
这一次课程设计,我完成了题目“读者-写者问题的实现”,更加系统地理解和掌握c语言的基本概念、语言特点和编程技巧,在应用c语言在程序设计方面得到系统锻炼,为将来用c进行软件开发打下良好基础。对程序设计思想也有了比较清晰的印象,为今后的程序设计奠定了一定的心理和技术上的准备。总的感觉,学到了很多知识,特别对于linux有了全面的接触和了解,也开始对linux产生了兴趣,它所开放的源码的确为学计算机的同志们提供了很好的平台。
读者-写者问题经典的线程同步问题的一个模型。经过读者写者问题的编写,我对同步机构应用有了深入的了解。懂得了运用信号量实现进程间的互斥。
实现了不让共享资源同时修改。用信号量上的原语操作使临界段问题的解决比较简单明了了。读者写者问题的编写,花的时间很多,也学到很多东西。
了解支持多道程序的并发操作系统设计中解决资源共享时进程间的同步与互斥的信号量机制。几天的试验,虽然难度有点大,但只要自己花时间去学习,还是会攻克困难的。
课程设计提高了我对所学知识的综合应用能力,全面检查并掌握所学的内容,培养独立思考、刻苦钻研的精神,在分析问题、解决问题的过程中,更是获得一种成功的喜悦,进而增加学习和应用的兴趣。同时也要督促自己在学习的过程中不断的完善自我,加强自己的动手操作能力,培养我的独立思考的那种思维方式。
总之,每一次课程设计不仅是我们学习的好机会,而且是我们锻炼实际动手能力的平台,虽然有难度的东西总会让人很抵触,比如在课设过程中有很多郁闷的时候,一个小小的错误一不小心就花去了自己一上午的时间,所以在这个过程中能够磨练人的意志与耐心,最后感谢老师的指导与监督。
附:主要源**。
#include ""
#include <>
#include <>
#include <>
#include <>
#include <>
#include <>
#define reader 'r读者。
#define writer 'w写者。
#define inte_per_sec 1000每秒时钟中断的数目。
#define max_thread_num 64最大线程数。
#define max_file_num 32最大文件数目数。
#define max_str_len 32字符串的长度。
int readcount=0读者数目。
int writecount=0写者数目。
critical_section rp_write临界资源。
critical_section cs_write;
critical_section cs_read;
struct threadinfo
int serial线程序号。
char entity线程类别(判断是读者还是写者线程)
double delay线程延迟时间。
double persist线程读写操作时间。
/ 读者优先---读者线程。
/p:读者线程信息。
void rp_readerthread(void *p)
//互斥变量。
handle h_mutex;
h_mutex=openmutex(mutex_all_access,false,"mutex_for_readcount");
dword wait_for_mutex等待互斥变量所有权。
dword m_delay延迟时间。
dword m_persist读文件持续时间。
int m_serial线程序号。
从参数中获得信息。
m_serial=((threadinfo*)(p))-serial ;
m_delay=(dword)((threadinfo*)(p))-delay *inte_per_sec);
m_persist=(dword)((threadinfo*)(p))-persist *inte_per_sec);
sleep(m_delay延迟等待。
printf("reader thread %d sents the reading require./n",m_serial);
//等待互斥信号,保证对readcount 的访问,修改互斥。
wait_for_mutex=waitforsingleobject(h_mutex,-1);
//读者数目增加。
readcount++;
if(readcount==1)
releasemutex(h_mutex释放互斥信号。
//读文件。
printf("reader thread %d begins to read file./n",m_serial);
sleep(m_persist);
//退出线程。
printf("reader thread %d finished reading file./n",m_serial);
//等待互斥信号,保证对readcount的访问,修改互斥。
wait_for_mutex=waitforsingleobject(h_mutex,-1);
//读者数目减少。
readcount--;
if(readcount==0)
releasemutex(h_mutex释放互斥信号。
/p:写者线程信息。
void rp_writerthread(void *p)
操作系统课程设计
课程设计 河北大学工商学院。装。订。线。操作系统课程设计。题目 操作系统课程设计 学院工商学院 学部信息科学与工程 专 操作系统课程设计。题目 操作系统课程设计 学院工商学院 学部信息科学与工程 专业计算机类 学号 姓名。指导教师。年 6 月 24 日。设备管理 2 2.1设计任务2 2.2设计要求...
操作系统课程设计
银行家算法模拟。系别 班级 组员 银行家算法模拟。1.课程设计目的。通过本次课程设计,加深对最经典的避免死锁的银行家算法的理解,掌握死锁形成必要条件 安全状态等概念的理解,通过用c语言编程模拟该算法,并在windows平台上实现,更好地掌握操作系统的原理及实现方法。2.任务及要求。设n为系统进程的个...
操作系统课程设计
学生实习实训报告。实习类型 操作系统课程设计 学号 0901110005 学生姓名 田兴杰 指导教师 曹春梅 专业班级 信息安全技术0901班 院 部 电子信息系 2011年 1 月 7日。实习实训成绩评定表。目录。目录3 摘要4关键字4 1.1虚拟机简介5 1.1.1 一般意义的虚拟机5 1.1....