下载此文档

操作系统课程方案进程同步模拟方案——生产者和消费者问题张方纪.doc


文档分类:办公文档 | 页数:约17页 举报非法文档有奖
1/17
下载提示
  • 1.该资料是网友上传的,本站提供全文预览,预览什么样,下载就什么样。
  • 2.下载该文档所得收入归上传者、原创者。
  • 3.下载的文档,不会出现我们的网址水印。
1/17 下载此文档
文档列表 文档介绍
薁莀螅学号:薃00614芁蒁课程设计膈芇肁艿芆题目螆进程同步模拟设计螂——生产者和消费者问题芀学院蕿计算机科学与技术学院膅专业蒂计算机科学与技术莁班级螇0806薅姓名芃张方纪腿指导教师聿孙玉芬羄羃膀膈2010蒃年螃1节月莆20***日蒄聿蚈课程设计任务书薆芄学生姓名:张方纪专业班级:计算机0806肀指导教师:孙玉芬工作单位:计算机科学与技术学院螇题目:进程同步模拟设计——生产者和消费者问题羆初始条件::阅读操作系统的进程管理章节内容,对进程的同步和互斥,以及信号量机制度有深入的理解。:掌握一种计算机高级语言的使用。腿要求完成的主要任务:(包括课程设计工作量及其技术要求,以及说明书撰写等具体要求)。:罿⑴需求分析;芈⑵功能设计(数据结构及模块说明);袄⑶开发平台及源程序的主要部分;膁⑷测试用例,运行结果与运行情况分析;肀⑸自我评价与总结:莆i)你认为你完成的设计哪些地方做得比较好或比较出色;芄ii)什么地方做得不太好,以后如何改正;羂iii)从本设计得到的收获(在编写,调试,执行过程中的经验和教训);肂iv)完成本题是否有其他方法(如果有,简要说明该方法);螈蚃时间安排:蚂设计安排一周:周1、周2:完成程序分析及设计。衿周2、周3:完成程序调试及测试。袇周4、周5:验收、撰写课程设计报告。莆蒂(注意事项:严禁抄袭,一旦发现,一律按0分记)羁艿螆指导教师签名:年月日膃系主任(或责任教师)签名:年月日螈进程同步模拟设计——生产者和消费者问题莇课设任务芅本课程设计的任务在于,通过编写一个具体的有关操作系统进程同步互斥的经典问题,加强对操作系统实现进程间同步与互斥的机制的理解。同时培养提出问题、发现知识、使用工具、解决问题的能力。袃具体地,我们要编制出一个程序,利用PV原语以及进程创建、同步、互斥、销毁等相关的系统调用来模拟“生产者—消费者”问题。蝿背景介绍蒆“生产者—消费者”问题(theproducer-consumerproblem)蚅问题描述:蚄一组生产者向一组消费者提供消息,它们共享一个有界缓冲区n,生产者向其中投放消息,消费者从中取得消息。袁规则:袈对于生产者进程:产生一个数据,当要送入缓冲区时,要检查缓冲区是否已满,若未满,则可将数据送入缓冲区,并通知消费者进程;否则,等待;肄对于消费者进程:当它去取数据时,要看缓冲区中是否有数据可取,若有则取走一个数据,并通知生产者进程,否则,等待。莄缓冲区是个临界资源,因此,诸进程对缓冲区的操作程序是一个共享临界区,所以,还有个互斥的问题。蚈问题分析:羇该问题涉及到操作系统进程管理当中的两个重要概念——同步和互斥。薃同步,表现在生产者和消费者需要协同工作,步调不能拉开太大(由缓冲区大小n决定,n越大,缓冲空间越大,步调可以拉得越开;n=1时,必须是生产一个,消费一个,生产者和消费者就完全同步了)。当步调差距超过极限时,走在前面的当前进程(生产者)调用P原语时由于资源耗尽,被阻塞;步调靠后的继续向前推进。由此实现同步。膄互斥,表现在生产者与消费者、生产者与生产者、消费者与消费者任何两个成员之间必须互斥地使用缓冲区。当有一个成员进入缓冲区存/取产品时,其他成员将被关在门外排队等候(被阻塞);当完毕时,通知队首成员进入。螆由操作系统理论可知,我们需要三个信号量,分别命名full,empty,mutex,来分别代表消费者的可用资源数、生产者的可用资源数、缓冲区是否可用。初值:full=0(消费者无资源可用),empty=N(生产者有N个资源可用,N代表缓冲区大小),mutex=1(缓冲区可用)。蒅要模拟多个进程的并发,我们要使用一个系统调用,使多个函数或程序同时地执行。鉴于VC下这样的函数太过复杂,Linux下笔者暂未找到,因此我们使用Toyix系统提供的一个系统调用函数:cobegin。其说明如下:芃cobegin蚇原型:袇intcobegin();薄功能:蚂创建多个子进程并发执行函数。蒇参数:蚄函数名用0结束,例如:cobegin(f1,f2,f3,0);蚂返回值:膂创建子进程的个数。膈说明:蚆所有子进程共享数据段,主进程撤销,所有子进程将被撤销。肄我们于下一小节具体讲述有关Toyix的背景知识。薁Toyix简介羈概述螇Toyix是我国著名计算机教育家王爽老师开发的一个专门用于操作系统基础理论教学的软件。该软件很好的解决了目前存在于计算机专业操作系统课程教学中无法使学****者获得实践体验和对理论直观的了解的问题。以下是Toyix软件的重要意义和特点的描述:(该软件下载地址的操作系统教学中存在的问题:羀重理论轻实践,学****的理论没有与编程结合,使学****者无法获得实际的体验。蚈以unix或windows为平台实践

操作系统课程方案进程同步模拟方案——生产者和消费者问题张方纪 来自淘豆网www.taodocs.com转载请标明出处.

非法内容举报中心
文档信息
  • 页数17
  • 收藏数0 收藏
  • 顶次数0
  • 上传人花开花落
  • 文件大小298 KB
  • 时间2019-05-07