黑马程序员技术交流社区
标题:
模拟实现——生产消费问题(给个分咯老师)
[打印本页]
作者:
天山
时间:
2014-4-24 12:20
标题:
模拟实现——生产消费问题(给个分咯老师)
1 生产消费流程系统, 需要用到线程,、
生产者和消费者可以是两个独立的并发主体。,共有四个部分
(一) Q 类, 仓库,有两个方法,1 放入仓库方法,不断得把货物放进仓库,2 出库,不断的把货物从仓库搬出,
(二)Producer ,生产类, 不断调用 仓库 进库方法 put(); 把货物放进仓库;
(三) Comsumer 消费类 三个消费线程, 不断调用 仓库 出库方法 get(); 把货物拿出来 ;
(四) PC类, MAIN 函数, 生成 生产 消费线程,
package com.isoftstone.interview;
public class Q { //仓库,进货,出货,
int n; //库存量
private boolean p=false;
//防死锁 判断,用户 阻塞唤醒消费 生产进程
public synchronized int get(){
while(!p){ //必须put方法 先调用,把P值 设为ture ,然后 三个消费进程 争夺资源
try{
wait();
}
catch(InterruptedException e)
{
e.printStackTrace();
}
}
System.out.println(Thread.currentThread().getName()+"Get!"+n);
p=false;
notifyAll();
//notify();
return n;
}
public synchronized void put(int n)
{
while(p)
try{
wait();
}
catch(InterruptedException e)
{
System.out.println(e.toString());
}
this.n=n;
System.out.println(Thread.currentThread().getName()+"Put!"+n);
p=true; //值为true ,放入了一次货物 通知消费进场 取货,
notifyAll();
//notify();
}
}
package com.isoftstone.interview;
public class Producer implements Runnable {
Q q;
Producer(Q q)
{
this.q=q; //构造器中生成 线程;
new Thread(this,"Producer").start(); //need attention
}
//覆盖 继承下来的run方法
public void run(){
int i=0;
while(true) //生产方法 不断 访问put方法 放货物
{
q.put(i++); //生产物品放入仓库,
}
}
}
package com.isoftstone.interview;
public class Consumer implements Runnable {
Q q;
Consumer(Q q){
this.q=q;
new Thread(this,"消费者1_").start();
new Thread(this,"消费者2_").start();
new Thread(this,"消费者3_").start();
} //覆盖继承run 方法
public void run(){
//因为不止一个用户在 抢占仓库库存 需用互斥 synchronized
synchronized (q){
while(true){
q.get();//消费进程不断取货物,消费,
}
}
}
}
package com.isoftstone.interview;
public class PC {
public static void main(String []args)
{
Q q=new Q();
Thread thread=Thread.currentThread();
new Producer(q);
new Consumer(q);
try{
thread.sleep(10000); //线程 等待10秒,让生产线程 先生产一些产品来
}
catch(InterruptedException e)
{
e.printStackTrace();
}
}
}
作者:
天山
时间:
2014-4-24 12:29
哎呀,给力哇, 我可以去申请 面试了,深圳等着我!!!!
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2