实验一 进程同步

实验一 进程同步

ID:9994164

大小:67.46 KB

页数:8页

时间:2018-05-20

实验一 进程同步_第1页
实验一 进程同步_第2页
实验一 进程同步_第3页
实验一 进程同步_第4页
实验一 进程同步_第5页
资源描述:

《实验一 进程同步》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、实验一进程同步专业班级:信息安全131学生名字:吴文涛指导老师:黄汝维实验内容:系统中有一个打印进程printer和若干个顾客进程customer_i(i>20),缓冲池有5个缓冲区,如果没有customer进程需要打印,则printer进程阻塞。当customer进程需要打印时候,唤醒Printer进程;如果没有缓冲区,customer必须放弃打印。请设计同步机制实现以上要求实验环境:WIN7系统微机一台,esclipse实验思路:本体是典型 生产者-消费者(producer-consumer)问题,也可以称作有界缓冲区(bound

2、ed-buffer)问题,两个进程共享一个公共的固定大小的缓冲区。其中一个是生产者,用于将消息放入缓冲区;另外一个是消费者,用于从缓冲区中取出消息。问题出现在当缓冲区已经满了,而此时生产者还想向其中放入一个新的数据项的情形,其解决方法是让生产者此时进行休眠,等待消费者从缓冲区中取走了一个或者多个数据后再去唤醒它。同样地,当缓冲区已经空了,而消费者还想去取消息,此时也可以让消费者进行休眠,等待生产者放入一个或者多个数据时再唤醒它实验目的:通过编写程序实现进程同步和互斥,掌握有关进程(线程)同步与互斥的原理,以及解决进程(线程)同步和互斥

3、的算法,从而进一步巩固进程(线程)同步和互斥等有关的内容。实验代码:package进程同步3;/**生产者与消费者模型中,要保证以下几点:*1同一时间内只能有一个生产者生产生产方法加锁sychronized*2同一时间内只能有一个消费者消费消费方法加锁sychronized*3生产者生产的同时消费者不能消费生产方法加锁sychronized*4消费者消费的同时生产者不能生产消费方法加锁sychronized*5共享空间空时消费者不能继续消费消费前循环判断是否为空,空的话将该线程wait,释放锁允许其他同步方法执行*6共享空间满时生产者

4、不能继续生产生产前循环判断是否为满,满的话将该线程wait,释放锁允许其他同步方法执行*///主类publicclassPrinterandCustomer{publicstaticvoidmain(String[]args){StackBaskets=newStackBasket();Printerp=newPrinter(s);Customerc=newCustomer(s);Threadtp=newThread(p);Threadtc=newThread(c);tp.start();tc.start();}}//classwen

5、jian{privateintid;wenjian(intid){this.id=id;}publicStringtoString(){return"第"+id;}}//共享栈空间classStackBasket{wenjiansm[]=newwenjian[6];intindex=0;/***show生产方法.*show该方法为同步方法,持有方法锁;*show首先循环判断满否,满的话使该线程等待,释放同步方法锁,允许消费;*show当不满时首先唤醒正在等待的消费方法,但是也只能让其进入就绪状态,*show等生产结束释放同步方法锁后消

6、费才能持有该锁进行消费*@paramm元素*@return没有返回值*/publicsynchronizedvoidpush(wenjianm){try{while(index==sm.length){System.out.println("!!!!!!!!!打印店人满了!!!!!!!!!");Thread.sleep((long)(Math.random()*3000));System.out.println(m+"份文件被顾客放弃打印");this.wait();}this.notify();}catch(InterruptedE

7、xceptione){e.printStackTrace();}catch(IllegalMonitorStateExceptione){e.printStackTrace();}sm[index]=m;index++;System.out.println(m+"个顾客,打印"+m+"份文件");}/***show消费方法*show该方法为同步方法,持有方法锁*show首先循环判断空否,空的话使该线程等待,释放同步方法锁,允许生产;*show当不空时首先唤醒正在等待的生产方法,但是也只能让其进入就绪状态*show等消费结束释放同步方法

8、锁后生产才能持有该锁进行生产*@parambtrue表示显示,false表示隐藏*@return没有返回值*/publicsynchronizedwenjianpop(){try{while(index==0){Syst

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。