实验一 进程同步.docx_第1页
实验一 进程同步.docx_第2页
实验一 进程同步.docx_第3页
实验一 进程同步.docx_第4页
实验一 进程同步.docx_第5页
已阅读5页,还剩4页未读 继续免费阅读

下载本文档

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

文档简介

实验一 进程同步专业班级:信息安全131学生名字:吴文涛指导老师:黄汝维实验内容:系统中有一个打印进程printer 和 若干个顾客进程customer_i(i20),缓冲池有5个缓冲区,如果没有customer进程需要打印,则printer进程阻塞。当customer进程需要打印时候,唤醒Printer进程;如果没有缓冲区,customer必须放弃打印。请设计同步机制实现以上要求实验环境:WIN7系统微机一台 ,esclipse实验思路:本体是典型生产者-消费者(producer-consumer)问题,也可以称作有界缓冲区(bounded-buffer)问题,两个进程共享一个公共的固定大小的缓冲区。其中一个是生产者,用于将消息放入缓冲区;另外一个是消费者,用于从缓冲区中取出消息。问题出现在当缓冲区已经满了,而此时生产者还想向其中放入一个新的数据项的情形,其解决方法是让生产者此时进行休眠,等待消费者从缓冲区中取走了一个或者多个数据后再去唤醒它。同样地,当缓冲区已经空了,而消费者还想去取消息,此时也可以让消费者进行休眠,等待生产者放入一个或者多个数据时再唤醒它实验目的:通过编写程序实现进程同步和互斥,掌握有关进程(线程)同步与互斥的原理,以及解决进程(线程)同步和互斥的算法,从而进一步巩固进程(线程)同步和互斥等有关的内容。实验代码:package 进程同步3;/* 生产者与消费者模型中,要保证以下几点:* 1 同一时间内只能有一个生产者生产生产方法加锁sychronized* 2 同一时间内只能有一个消费者消费消费方法加锁sychronized* 3 生产者生产的同时消费者不能消费生产方法加锁sychronized* 4 消费者消费的同时生产者不能生产消费方法加锁sychronized* 5 共享空间空时消费者不能继续消费消费前循环判断是否为空,空的话将该线程wait,释放锁允许其他同步方法执行* 6 共享空间满时生产者不能继续生产生产前循环判断是否为满,满的话将该线程wait,释放锁允许其他同步方法执行 */主类public class PrinterandCustomerpublic static void main(String args) StackBasket s = new StackBasket();Printer p = new Printer(s);Customer c = new Customer(s);Thread tp = new Thread(p);Thread tc = new Thread(c);tp.start();tc.start();/class wenjianprivate int id;wenjian(int id)this.id = id;public String toString()return 第 + id;/共享栈空间class StackBasketwenjian sm = new wenjian6;int index = 0;/* * show 生产方法.* show 该方法为同步方法,持有方法锁;* show 首先循环判断满否,满的话使该线程等待,释放同步方法锁,允许消费;* show 当不满时首先唤醒正在等待的消费方法,但是也只能让其进入就绪状态,* show 等生产结束释放同步方法锁后消费才能持有该锁进行消费* param m 元素* return 没有返回值 */ public synchronized void push(wenjian m)trywhile(index = sm.length)System.out.println(!打印店人满了!);Thread.sleep(long) (Math.random() * 3000);System.out.println(m+份文件被顾客放弃打印);this.wait();this.notify();catch(InterruptedException e)e.printStackTrace();catch(IllegalMonitorStateException e)e.printStackTrace();smindex = m;index+;System.out.println(m +个顾客,打印+ m+ 份文件 );/* * show 消费方法* show 该方法为同步方法,持有方法锁* show 首先循环判断空否,空的话使该线程等待,释放同步方法锁,允许生产;* show 当不空时首先唤醒正在等待的生产方法,但是也只能让其进入就绪状态* show 等消费结束释放同步方法锁后生产才能持有该锁进行生产* param b true 表示显示,false 表示隐藏 * return 没有返回值 */ public synchronized wenjian pop()trywhile(index = 0)System.out.println(!店里没人了!);this.wait();this.notify();catch(InterruptedException e)e.printStackTrace();catch(IllegalMonitorStateException e)e.printStackTrace();index-;System.out.println(smindex + 份文件打印完毕,店里剩余 + index + 个顾客 );return smindex;class Printer implements RunnableStackBasket ss = new StackBasket();Printer(StackBasket ss)this.ss = ss;/* * show 生产进程. */ public void run()for(int i = 0;i 25;i+)wenjian w = new wenjian(i);ss.push(w);tryThread.sleep(int)(Math.random()*500);catch(InterruptedException e)e.printStackTrace();class Customer implements RunnableStackBasket ss = new StackBasket();Customer(StackBasket ss)this.ss = ss;/* * show 消费进程.*/ public void run()for(int i = 0;i 25;i+)wenjian w = ss.pop();tryThread.sleep(int)(Math.ran

温馨提示

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

评论

0/150

提交评论