多进程同步方法演示“生产者-消费者”问题.docx

上传人:王** 文档编号:718907 上传时间:2023-12-24 格式:DOCX 页数:10 大小:99.94KB
下载 相关 举报
多进程同步方法演示“生产者-消费者”问题.docx_第1页
第1页 / 共10页
多进程同步方法演示“生产者-消费者”问题.docx_第2页
第2页 / 共10页
多进程同步方法演示“生产者-消费者”问题.docx_第3页
第3页 / 共10页
多进程同步方法演示“生产者-消费者”问题.docx_第4页
第4页 / 共10页
多进程同步方法演示“生产者-消费者”问题.docx_第5页
第5页 / 共10页
多进程同步方法演示“生产者-消费者”问题.docx_第6页
第6页 / 共10页
多进程同步方法演示“生产者-消费者”问题.docx_第7页
第7页 / 共10页
多进程同步方法演示“生产者-消费者”问题.docx_第8页
第8页 / 共10页
多进程同步方法演示“生产者-消费者”问题.docx_第9页
第9页 / 共10页
多进程同步方法演示“生产者-消费者”问题.docx_第10页
第10页 / 共10页
亲,该文档总共10页,全部预览完了,如果喜欢就下载吧!
资源描述

《多进程同步方法演示“生产者-消费者”问题.docx》由会员分享,可在线阅读,更多相关《多进程同步方法演示“生产者-消费者”问题.docx(10页珍藏版)》请在优知文库上搜索。

1、青岛理工大学操作系统课程设计报告院(系):计算机工程学院专业:计算机科学与技术专业学生姓名:班级:学号:题目:用多进程同步方法演示生产者演肖费者问题起迄日期:设计地点:指导教师:年度第学期完成日期:年月日一、课程设计目的本次进行操作系统课程设计的主要任务是设计一个模拟生产者消费者工作的系统。这个问题中有一种生产者和一种消费者,生产者和消费者对同一个缓冲区进行操作,互斥的访问缓冲区。本次课程设计的目的就是加深对多进程如何正确访问资源的认识,同时掌握信号量在互斥访问时应该如何正确有效地使用。掌握生产者消费者问题的解决流程和方法,提高编程能力、解决问题的能力和查阅文档的能力。二、课程设计内容与要求1

2、、设计目的:通过研究LinUX的进程同步机制和信号量,实现生产者消费者问题的并发控制。2、说明:有界缓冲区内设有20个存储单元,放入取出的产品设定为20个100以内的随机整数。3、设计要求:1)生产者与消费者均有二个以上2)生产者和消费者进程的数目在程序界面上可调,在运行时可随时单个增加与减少生产者与消费者3)生产者的生产速度与消费者的消费速度均可在程序界面调节,在运行中,该值调整后立即生效4)生产者生产的产品由随机函数决定5)多个生产者或多个消费者之间必须有共享对缓冲区进行操作的函数代码6)每个生产者和消费者对有界缓冲区进行操作后,即时显示有界缓冲区的全部内容、当前生产者与消费者的指针位置,

3、以及生产者和消费者线程标识符7)采用可视化界面,可在运行过程中随时暂停,查看当前生产者、消费者以及有界缓冲区的状态三、系统分析与设计1、系统分析系统分析1 .此次课程设计的任务是生产者消费者问题的模拟演示,需要处理的数据有:生产者进程数目,消费者进程数目,生产者生产速度,消费者消费速度,缓冲区中产品的个数,以及生产、消费产品的指针。2 .程序中需要缓冲区中的信息可以动态演示,生产者、消费者的个数以及生产、消费时的速度可以随时调节,同时为了使程序更加友好,应该具有开始、暂停、停止等相关可操作按钮。3 .系统对外的界面如下:1)对进程个数的修改:点击生产者、消费者进程数据文本框下的增加、减少按钮2

4、)对速度的修改:速度值默认为2000ms/个,如需修改,那么在速度文本框中输入所修改的值,点击修改按钮即可进行修改。1 )需要开始模拟时,点击右上方的开始按钮。如需暂停模拟过程,可点击暂停按钮。当需要运行完毕时,点击停止按钮,进程工作停止4 .此次使用java平台实现,保证了程序在各种机器的运行,只需要事前建立java的运行环境即可,便于程序的移植5 .系统界面如下:申请空缓冲区C 匚 I rvy、,r t ,、c 1 t 1CNoL仓库己满,线程阻塞释放缓冲区消3申请空缓冲区full=full+11、系统测试(1)因为当生产者在缓冲区满了以后自动阻塞,需要消费者唤醒,所以需要测试唤醒的实现是

5、否正常。测试说明测试名称用多进程同步方法演示“生产者-消费者问题测试目的验证生产者能被消费者唤醒测试技术单元测试测试方法黑盒测试法测试用例测试内容当生产者生产满缓冲区后,开始增加消费者,唤醒生产者测试步骤增加生产者等待缓冲区被用完增加消费者测试数据增加生产者到2缓冲区产品数量20缓冲区空闲位为0苹果消费者增加到3预期结果缓冲区开始增加产品缓冲区满生产者阻塞生产者被唤醒,缓冲区中产品数量减少测试结果与预期相符与预期相符与预期相符(2)因为当生产者在缓冲区满了以后自动阻塞,需要消费者唤醒,所以需要测试唤醒的实现是否正常。测测试名称用多进程同步方法演示“生产者-消费者问题试测试目的验证多个生产者和消

6、费者互斥操作缓冲区说测试技术单元测试明测试方法黑盒测试法测试内容缓冲区为空,消费者阻塞时,生产者唤醒消费者测试用例测试步骤开始生产产品,缓冲区为空空闲位20开始消费产品,程终止生产线开始增加生产者减少消费者测试数据生产者数量5生产者减少到0增加消费者到5增加生产者到5减少消费者到2预期结果缓冲区内产品数量每次增加5个消费完成产品,消费者阻塞唤醒消费者,缓冲区中产品增加测试结果与预期相符与预期相符与预期相符3)测试生产者用消费者的速度是否可以诵测测试名称用多进程同步方法演示“生产者-消费者问题试测试目的苹果、橘子生产者和苹果、橘子消费者速度可以调节说测试技术单元测试明测试方法黑盒测试法;则测试内

7、容调节生产者和消费者速度试测试步骤开始程序运行输入生产者、消费者速度值点击修改按钮用测试数据生产者速度2000生产者速度值000点击修改例消费者速度2000消费者速度值10预期结果缓冲区开始被操作界面文本框中显示速度值速度均变化到IoOo测试结果与预期相符与预期相符与预期相符2、调试分析:1 .在编写过程中,由于函数较多,开始时由于名称不够清晰,程序出现错误。2 .测试运行过程中,由于函数名称的相似,出现引用混乱的情况,程序无法正常运行。3 .在制作界面时,由于遗忘了chuangkou.add(jp)jchuangkou.setVisible(true):两个语句,导致界面无法正常显示。4 .

8、制作界面时,对各个控件的坐标和大小考虑不周,导致界面混乱,影响美观。五、用户手册1 .使用的语言和平台本次实验使用的是java语言的eclipse平台2 .对于程序运行环境的考前须知需要安装java运行环境,eclipss平台不需要安装,只需要下载完成就可以使用。3 .程序使用步骤图I:系统登录界面。图2:生产者速度调节图3:消费者速度调节图4:生产者数量调节图5:消费者数量调节图6::控制界面图7:动态显不缓冲区4 .程序使用步骤:I)单击开始按钮,程序开始初始化执行2)点击增加按钮分别增加生产者和消费者,可以看到可视化缓冲区开始运动3)在速度调节局部调节生产者和消费者的速度,可以看到缓冲区

9、出现预期的产品种类和数量的变化。六、程序清单classConsumerextendsThreadprivatehuanchongquhcq;保存一个缓冲区类的引用Staticlongspeed=2000;/speed表示消费者线程的速度Staticintcpause=0;/cpause1:booleanout=false;定义构造方法,接收一个缓冲区类型的变量publicConsumer(huanchongquhcq)this.hcq=hcq;run()方法调用接收的缓冲区类型的变量指向的decrease0方法,开始消费元素。Overridepublicvoidrun()while(!out)

10、if(out)break;if(cpouse=1)tryThread.sLeep(speed);catch(InterruptedExceptione)e.printStackTrace();hcq.Consume();classProducerextendsThreadprivatehuanchongquhcq;定义缓冲区类的引用。Staticlongspeed=20。;定义SPeeCl变量,表示线程速度booleanout=false;Publicstaticintppatzse=0;/DPaUSe变量用勺开始与暂停定义构造方法,接收一个缓冲区类型的变量publicProducer(hua

11、nchongquhcq)this.hcq=hcq;publicvoidchangeout()out=!out;PUn()方法调用缓冲区类型变量指向的对象的increase0方法,开始生产元素。Overridepublicvoidrun()while(!out)if(out)break;if(ppouse=1)tryThreadSIeep(speed);catch(InterruptedExceptione)e.printStackTrace();hcq.Produce();classhuanchongqunumber表示动态缓冲区中元素的数量staticintnu/nber=0;staticb

12、ooleanF_F=newboolean20;缓冲区状态控制Staticintstorage=newint20;staticSemaphoreempty=newSemaphore(20);staticSemaphorefuLL=newSemaphore(0);staticSemaphorechanpin=newSemaphore(0);staticSemaphoremutex=newSemaphore(I);Staticintcpnum=。;Staticintpointcp=-1;publichanchongqu()for(inti=0;i20;i+)JFi=false;storagei=,0

13、,;publicvoidProduce()e/npty.acquire0;信号量的P操作,中请空缓冲区h吐exacquire();互斥信号量if(pointcp+1!=20)PoiCtCp+;E_Fpointcp=true;/将生产了产品的标志位设为满cpnum+;storagepointcp=(int)(Mathrdow()*99+0);存储生产的产品Stringstr2=Thread.currentThread().getName();pc亡2append(生产者”+str2+”运行n“);number+;pct2append(仓库中的产品个数为”+number+”n“);pctl.app

14、end(它们是:n);for(intj=0;j20;j+)if(storagej!=,)pc.tl.append(,(h+j+h)+storagej+“);elsepc.tl.append(,”);if(number三三20)pc.tai.append(,n仓库已满);pc.tai.append(,n,);wtex.release();释放互斥锁fuLL.release();增加满信号量的值chanpin.release();增加产品信号量的值publicvoidConsume()chnpin.acquire();申请获得产品fuLL.acquire();申请满缓冲区砒亡ex.acquire();互斥进入临界区Stringstr2=Thread.currentThread().getName();pc.S2叩Pend(消费者”+Str2+运行r);number-;cpnum-;E_Fpoi

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 高等教育 > 大学课件

copyright@ 2008-2023 yzwku网站版权所有

经营许可证编号:宁ICP备2022001189号-2

本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!