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

付费下载

下载本文档

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

文档简介

信控学院java程序设计实验PAGE实验报告课程名称:java程序设计题目:生产者消费者院(系):信息与控制工程专业班级:计算机1202姓名:张金涛学号:120620226指导教师:张翔2014年12月17月实验目的实现生产者-消费者问题,深刻理解进程同步问题。

实验环境装有jdk及eclipse的计算机一台实验内容Java程序实现生产者消费者问题代码及注释packagepro_con;publicclassMain{ publicstaticvoidmain(String[]args) {newMain().start(); } publicvoidstart() { Buffersbuffers=newBuffers(5); String[]idList4={"5","6"}; String[]idList7={"1","3","5"}; newPro_Thread("生产者1",buffers,5,"1").start(); newPro_Thread("生产者2",buffers,4,"2").start(); newPro_Thread("生产者3",buffers,2,"3").start(); newPro_Thread("生产者5",buffers,7,"5").start(); newPro_Thread("生产者6",buffers,1,"6").start(); newCon_Thread("消费者4",buffers,6,idList4).start(); newCon_Thread("消费者7",buffers,3,idList7).start(); }}Buffers.java:packagepro_con;//缓冲区publicclassBuffers{privateintproductNum;//缓冲单元数目publicstaticProductproducts[];//缓冲区队列privateintcount=0;//记录使用的缓冲区单元 publicBuffers(intproductNum) { super(); ductNum=productNum; ducts=newProduct[productNum]; this.initBuffersPool(); } //初始化该缓冲区 publicvoidinitBuffersPool() { for(inti=0;i<products.length;i++) { products[i]=newProduct(); products[i].setProductId("-1"); } } //取出产品 publicsynchronizedProductget(Stringid) { Productproduct=null; while(count==0) { try { super.wait(); }catch(InterruptedExceptione) { e.printStackTrace(); } } this.notifyAll(); intx=-1; inti=0; for(i=0;i<products.length;i++) { if(products[i].getProductId().equals(id)) { x=i; product=products[i]; products[i].setProductId("-1"); break; } } while(i==products.length) { try { super.wait(); for(i=0;i<products.length;i++) { if(products[i].getProductId()==id) { x=i; product=products[i]; products[i].setProductId("-1"); break; } } }catch(InterruptedExceptione) { e.printStackTrace(); } } notifyAll(); System.out.println(Thread.currentThread().getName()+"开始消费\t" +id+"产品"); count--; System.out.println(Thread.currentThread().getName()+"成功消费\t"+id+"产品\n"); System.out.println("缓冲区["+x+"]\t"+products[x]+"\n"); returnproduct; } //添加产品 publicsynchronizedbooleanput(StringproductId) { booleanbool=false; //如果满了,就等待消费者消费 while(count==products.length) { try{ super.wait(); }catch(Exceptione){ e.printStackTrace(); } } this.notifyAll(); inti=findPutLocation(); System.out.println(Thread.currentThread().getName()+"开始在\t缓冲区" +i+"\t生产"); bool=true; products[i].setProductId(productId); count++; System.out.println(Thread.currentThread().getName()+"完成生产\n"); System.out.println("缓冲区["+i+"]\t"+products[i]+"\n"); returnbool; }//找一个合适的位置 publicsynchronizedintfindPutLocation() { intk=0; for(inti=0;i<products.length;i++) { if(products[i].getProductId().equals("-1")) { k=i; break; } } returnk; }}Product.java:packagepro_con;//产品publicclassProduct{privateStringproductId; publicStringgetProductId() { returnproductId; } publicvoidsetProductId(StringproductId) { ductId=productId; } publicStringtoString() { returnproductId; }}消费者线程:Con_Thread.java:packagepro_con;publicclassCon_ThreadextendsThread{ privatestaticfinalintbaseTime=1000; privateStringidList[];//消费者消费产品 privateintn;//延迟时间 privateBuffersbuffers;privateinti=0; publicCon_Thread(Stringname,Buffersbuffers,intn,StringidList[]) { super(name); this.idList=idList; this.n=n; this.buffers=buffers; } @Override publicvoidrun() { while(i<idList.length) { try { Thread.sleep(n*baseTime); System.out.println(Thread.currentThread().getName()+"请求消费\t" +idList[i]+"产品"); buffers.get(idList[i]); ++i; }catch(InterruptedExceptione) { e.printStackTrace(); } } }}生产者线程:Pro_Thread.java:packagepro_con;publicclassPro_ThreadextendsThread{ privatestaticfinalintbaseTime=1000; privateBuffersbuffers;privateintn;privateStringid; publicPro_Thread(Stringname,Buffersbuffers,intn,Stringid) { super(name); this.n=n; this.buffers=buffers; this.id=id; } @Override publicvoidrun() { try { Thread.sleep(n*baseTime); System.out

温馨提示

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

最新文档

评论

0/150

提交评论