生产者与消费者实验报告_第1页
生产者与消费者实验报告_第2页
生产者与消费者实验报告_第3页
生产者与消费者实验报告_第4页
生产者与消费者实验报告_第5页
已阅读5页,还剩10页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、生产者和消费者实验报告【实验目的】1. 加深对进程概念的理解,明确进程和程序的区别。2. 进一步认识并发执行的实质。3. 验证用信号量机制实现进程互斥的方法。4. 验证用信号量机制实现进程同步的方法。【实验要求】用c语言编程搭建“生产者和消费者”经典进程通信问题的环境。要求程序运行时,按任意键停止,显示当前系统的各个参数的值。提交实验报告,以及相关程序列表。打包成附件上传。【实验环境】VisualC+6.0【实验内容】1 .了解经典同步问题“生产者和消费者”生产者与消费者可以通过一个环形缓冲池联系起来,环形缓冲池由几个大小相等的缓冲块组成,每个缓冲块容纳一个产品。每个生产者可不断地每次往缓冲池

2、中送一个生产产品,而每个消费者则可不断地每次从缓冲池中取出一个产品。指针i和指针j分别指出当前的第一个空缓冲块和第一个满缓冲块。2 .分析和理解(1)既存在合作同步问题,也存在临界区互斥问题合作同步:当缓冲池全满时,表示供过于求,生产者必须等待,同时唤醒消费者;当缓冲池全空时,表示供不应求,消费者应等待,同时唤醒生产者。互斥:缓冲池显然是临界资源,所在生产者与消费都要使用它,而且都要改变它的状态。(2)基于环形缓冲区的生产者与消费者关系形式描述:公用信号量mutex:初值为1,用于实现临界区互斥生产者私用信号量empty:初值为n,指示空缓冲块数目消费者私用信号量full:初值为0,指示满缓冲

3、块数目整型量i和j初值为0,i指示首空缓冲块序号,j指示首满缓冲块序号3 3)PV原语varmutex,empty,full:semaphore;i,j:integer;buffer:array0.n-1ofitem;i:=j:=1;Procedureproducer;beginwhiletruedobeginproduceaproduct;P(empty);P(mutex);buffer(i):=product;i:=(i+1)modn;V(mutex);V(full);end;end;Procedureconsumer;beginP(full);P(mutex);goods:=buffer

4、(j);j:=(j+1)modn;V(mutex);V(empty);consumeaproduct;end;end;【实验源程序代码】#include#includeconstunsignedshortSIZE_OF_BUFFER=10;/缓冲区长度unsignedshortProductID=0;/产品号unsignedshortConsumeID=0;/将被消耗的产品号unsignedshortin=0;/产品进缓冲区时的缓冲区下unsignedshortout=0;标intg_bufferSIZE_OF_BUFFER;boolg_continue=true;HANDLEg_hMutex

5、;HANDLEg_hFullSemaphore;HANDLEg_hEmptySemaphore;DWORDWINAPIProducer(LPVOID);DWORDWINAPIConsumer(LPVOID);/ 产品出缓冲区时的缓冲区下/ 缓冲区是个循环队列/ 控制程序结束/ 用于线程间的互斥/ 当缓冲区满时迫使生产者等待/ 当缓冲区空时迫使消费者等待/ 生产者线程/ 消费者线程intmain()/创建各个互斥信号g_hMutex=CreateMutex(NULL,FALSE,NULL);g_hFullSemaphore=CreateSemaphore(NULL,SIZE_OF_BUFFER-

6、1,SIZE_OF_BUFFER-1,NULL);g_hEmptySemaphore=CreateSemaphore(NULL,0,SIZE_OF_BUFFER-1,NULL);/调整下面的数值,可以发现,当生产者个数多于消费者个数时,/生产速度快,生产者经常等待消费者;反之,消费者经常等待constunsignedshortPRODUCERS_COUNT=3;/生产者的个数constunsignedshortCONSUMERS_COUNT=1;/消费者的个数/总的线程数constunsignedshortTHREADS_COUNT=PRODUCERS_COUNT+CONSUMERS_COUN

7、T;HANDLEhThreadsPRODUCERS_COUNT;/各线程的handleDWORDproducerIDCONSUMERS_COUNT;/生产者线程的标识符DWORDconsumerIDTHREADS_COUNT;/消费者线程的标识符/创建生产者线程for(inti=0;iPRODUCERS_COUNT;+i)hThreadsi=CreateThread(NULL,0,Producer,NULL,0,&producerIDi);if(hThreadsi=NULL)return-1;/创建消费者线程for(i=0;iCONSUMERS_COUNT;+i)hThreadsPRODUCE

8、RS_COUNT+i=CreateThread(NULL,0,Consumer,NULL,0,&consumerIDi);if(hThreadsi=NULL)return-1;while(g_continue)if(getchar()/按回车后终止程序运行g_continue=false;return0;/生产一个产品。简单模拟了一下,仅输出新产品的ID号voidProduce()std:cerrProducing+ProductID.;std:cerrSucceedstd:endl;/把新生产的产品放入缓冲区voidAppend()-std:cerrAppendingaproduct.;g_

9、bufferin=ProductID;in=(in+1)%SIZE_OF_BUFFER;std:cerrSucceedstd:endl;/输出缓冲区当前的状态for(inti=0;iSIZE_OF_BUFFER;+i)std:couti:g_bufferi;if(i=in)std:cout-生产;if(i=out)std:cout-消费;std:coutstd:endl;/从缓冲区中取出一个产品voidTake()std:cerrTakingaproduct.;ConsumeID=g_bufferout;out=(out+1)%SIZE_OF_BUFFER;std:cerrSucceedstd

10、:endl;/输出缓冲区当前的状态for(inti=0;iSIZE_OF_BUFFER;+i)std:couti:g_bufferi;if(i=in)std:cout-生产;if(i=out)std:cout-消费;std:coutstd:endl;/消耗一个产品voidConsume()std:cerrConsumingConsumeID.;std:cerrSucceedo ailc iny 1 impending a 一一通1: & 生2; Bp B4: 05: 0一.Succe&d product .产Succeed7:H2 .Su.c a product消费Succeed0 0it4

11、5Pr-a due in 3 Ippendin生产8; HUsersAdminis4ratorDesklopXDebugVK-W. eye*AU入出deMistratcrDe5ktopDebu或肖凄君exe0:11:2消费2- 3L0J生产4:05:0&:0pi8S:0?!0Cansunin1SucceedProdueingf4SucceedAppendingapadutet*.Succeed0:L1=24一消费2:344:0生产5:0Gi8P:08:09:0具体程序见附件(网络查找)【实验反思】本次实验是关于生产者和消费者之间互斥和同步的问题。问题的实质是P,V操作,实验设一个共享缓冲区,生

12、产者和消费者互斥的使用,当一个线程使用缓冲区的时候,另一个让其等待知道前一个线程释放缓冲区为止。通过本次实验,我们对操作系统的P,V进一步的认识,深入的了解P,V操作的实质和其重要性。课本的理论知识进一步阐述了现实的实际问题。【实验思考题】1 .思考在“生产者和消费者”经典同步问题中,两个P操作是否可以互换位置,以及两个V操作是否可以互换位置。在生产者消费者问题中,如果将两个P操作,即P(full)和P(mutex)互换位置,或者P(empty)和P(mutex)互换位置,都可能引起死锁。考虑系统中缓冲区全满前时,若一生产者进程先执行了P(mutex)操作并获得成功,当再执行P(empty)操

13、作时,它将因失败而进入阻塞状态,它期待消费者执行V(empty)来唤醒自己。在此之前,它不可能执行V(mutex)操作,从而使企图通过P(mutex)进入自己的临界区的其他生产者和所有的消费者进程全部进入阻塞状态,从而引起系统死锁。类似地,消费者进程若先执行P(mutex),后执行P(full),同样可能造成死锁。V(full)和V(mutex)互换位置,或者V(empty)和V(mutcx)互换位置,则不会引起死锁,其影响只是使临界资源的释放略为推迟一些。2 .思考在“哲学家就餐”经典同步问题中,如何修改程序,可以保证不会发生死锁现象。(1)至多只允许有四位哲学家同时去拿左边的筷子,最终能保

14、证至少有一位哲学家能够进餐,并在用毕时能释放出他用过的两只筷子,从而使更多的哲学家能够进餐。(2)仅当哲学家的左、右两只筷子均可用时,才允许他拿起筷子进餐。(3)规定奇数号哲学家先拿他左边的筷子,然后再去拿右边的筷子,而偶数号哲学家则相反。按此规定,将是1、2号哲学家竞争1号筷子;3、4号哲学家竞争3号筷子。即五位哲学家都先竞争奇数号筷子,获得后,再去竞争偶数号筷子,最后总会有一位哲学家能获得两只筷子而进餐。5.思考在“读者与写者”经典同步问题中,如何修改程序,变为“写者优先”的算法。(写者优先的算法)varrmutex,wmutex,mutex,s:semaphore=1,1,1,1;wri

15、tecount:integer:=0;reader:beginrepeatwait(s);wait(rmutex);ifreadcount=0thenwait(wmutex);readcount:readcount+1;signal(rmutex);signal(s);performreadoperation;wait(rmutex);readcount:=readcount-1;ifreadcount=0thensignal(wmutex);signal(rmutex);untilfalse;endwriter:beginrepeatwait(mutex);ifwritecount=0thenwait(s);writecount:writecount+1;signal(mutex);wait(wmutex);performwriteoperation;signal(wmutex);wait(mutex);writecount:=writecount-1;ifwritecount=0thensignal(s);signal(mutex);untilfalse;end4.分析以下进程运行环境中出现的同步和互斥现象,列出相应的变量和参数。理发店理有一位理发师、一把

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论