欢迎来到天天文库
浏览记录
ID:39770404
大小:192.51 KB
页数:19页
时间:2019-07-11
《生产者消费者问题设计与实现》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、操作系统课程设计任务书学院计算机与信息工程专业计算机科学与技术课程名称操作系统题目生产者消费者问题设计与实现完成期限自2015年6月23日至2015年6月29日共1周内容及任务一、项目的目的1.理生产者消费者问题基本概念和工作原理,以及实现技术;2.理解并掌握生产者消费者问题相关算法,以及它的实现方法;3.掌握在eclipse环境下,系统开发的基本步骤和方法;4.掌握在eclipse环境下,设计和开发一个简单的生产者消费者问题系统来模拟操作系统中生产者消费者问题。二、项目任务的主要内容和要求1.精读并理解和掌握生产者消费者问题;2.编写程序来模拟生产者消费者问题的实现;3.编写应
2、用程序测试生产者消费者问题,并显示结果。三、项目设计(研究)思路本课程设计的基本思路是,首先理解和掌握生产者消费者问题的基本思想和原理,然后根据理解的基本思想和原理编程实现生产者消费者问题,最后通过数据分析生产者消费者问题。四、具体成果形式和要求成果:生产者消费者问题程序语言实现;设计说明书。要求:编写好的生产者消费者问题程序能够正确启动运行;设计说明书规范、合理。进度安排起止日期工作内容2015.6.23至2015.6.24熟悉相关内容2015.6.25至2015.6.26系统设计和实现2015.6.27至2015.6.29系统实现和撰写相关文档主要参考资料1.《计算机操作系统
3、》汤子瀛哲凤屏汤小丹主编西安电子科技大学出版社.2.《计算机操作系统概论》陈宏杨忠耀主编重庆邮电大学出版社.3.《计算机操作系统基本知识》廖成崔阳主编电子工业出版社.4.《操作系统实现与设计》陆刚望能主编电子工业出版社.5.《java程序语言设计》丁振凡主编,薛清华副主编清华大学出版社.指导教师意见(签字):年月日系(教研室)主任意见(签字):年月日目录1.选题背景12.设计思路13.过程讨论14.结果分析115.结论12参考文献13致谢13附录14指导教师评语19成绩评定191.选题背景生产者消费者问题是研究多线程程序时绕不开的经典问题之一,它描述是有一块缓冲区作为仓库,生产者
4、可以将产品放入仓库,消费者则可以从仓库中取走产品。解决生产者/消费者问题的方法可分为两类:(1)采用某种机制保护生产者和消费者之间的同步;(2)在生产者和消费者之间建立一个管道。第一种方式有较高的效率,并且易于实现,代码的可控制性较好,属于常用的模式。第二种管道缓冲区不易控制,被传输数据对象不易于封装等,实用性不强。因此本文只介绍同步机制实现的生产者/消费者问题。同步问题核心在于:如何保证同一资源被多个线程并发访问时的完整性。常用的同步方法是采用信号或加锁机制,保证资源在任意时刻至多被一个线程访问。Java语言在多线程编程上实现了完全对象化,提供了对同步机制的良好支持。在Java
5、中一共有四种方法支持同步,其中前三个是同步方法,一个是管道方法。2.设计思路2.1.生产者—消费者问题是一种同步问题的抽象描述。2.2计算机系统中的每个进程都可以消费或生产某类资源。当系统中某一进程使用某一资源时,可以看作是消耗,且该进程称为消费者。2.3而当某个进程释放资源时,则它就相当一个生产者3.过程论述首先,生产者和消费者可能同时进入缓冲区,甚至可能同时读/写一个存储单元,将导致执行结果不确定。这显然是不允许的。所以,必须使生产者和消费者互斥进入缓冲区。即某时刻只允许一个实体(生产者或消费者)访问缓冲区,生产者互斥消费者和其他任何生产者。其次,生产者不能向满的缓冲区写数据
6、,消费者也不能在空缓冲区中取数据,即生产者与消费者必须同步。当生产者产生出数据,需要将其存入缓冲区之前,首先检查缓冲区中是否有“空”存储单元,若缓冲区存储单元全部用完,则生产者必须阻塞等待,直到消费者取走一个存储单元的数据,唤醒它。若缓冲区内有“空”存储单元,生产者需要判断此时是否有别的生产者或消费者正在使用缓冲区,若是有,则阻塞等待,否则,获得缓冲区的使用权,将数据存入缓冲区,释放缓冲区的使用权。消费者取数据之前,首先检查缓冲区中是否存在装有数据的存储单元,若缓冲区为“空”,则阻塞等待,否则,判断缓冲区是否正在被使用,若正被使用,若正被使用,则阻塞等待,否则,获得缓冲区的使用权
7、,进入缓冲区取数据,释放缓冲区的使用权。153.1系统流程图3.1.1生产者流程图:3.1.2消费者流程图:153.1.3主程序流程图:3.1.4生产者:ProducerThread15//定义生产者线程classProducerThreadimplementsRunnable{intproductNo=0;//产品编号intid;//生产者IDpublicProducerThread(intid){this.id=id;}publicvoidrun(){while(isRun)
此文档下载收益归作者所有