java多线程之-并发协作【生产者与消费者】模型
对于多线程程序来说,不管c/c++ java python 等任何编程语言,生产者与消费者模型都是最为经典的。也就是可以说多线程的并发协作
对于此模型说明
1、生产者仅仅在仓库中未存贮满的时候生产,仓库满了就停止生产了。
2、消费者仅仅在仓库中有存储的产品才能消费,如果仓库为空就等待。
3、当消费者发现仓库中没有产品的时候回通知生产者进行生产
4、当生产者生产任何消费产品的时候,应该通知等待的消费者去消费。
package a;
import java.util.Queue;
import java.util.concurrent.LinkedBlockingQueue;
public class Main {
private static Queue<Apple> queue = new LinkedBlockingQueue<Main.Apple>();
private final static int MAX_COUNT = 30;
private static Object lock = new Object();
/**
* 苹果产品
* @author gaoyuandong
* @date 2015年7月24日 下午4:11:37
* @mail 466862016@qq.com
*/
private static class Apple {
private String name;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Apple(String name) {
super();
this.name = name;
}
public Apple() {
super();
// TODO Auto-generated constructor stub
}
}
/***
* 消费者
* @author gaoyuandong
* @date 2015年7月24日 下午4:09:49
* @mail 466862016@qq.com
*/
private static class Customer extends Thread {
@Override
public void run() {
while (true) {
synchronized (lock) {
if(queue.isEmpty()) {
try {
System.err.println("篮子里面没有苹果了,我好饿啊,我等待....");
lock.wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
} else {
queue.poll();
System.err.println("篮子里面有苹果了,我要吃苹果.... 还剩下:" + queue.size() +"个苹果" );
lock.notifyAll();
}
}
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
/***
* 生产者
* @author gaoyuandong
* @date 2015年7月24日 下午4:08:58
* @mail 466862016@qq.com
*/
private static class Producer extends Thread {
@Override
public void run() {
while (true) {
synchronized (lock) {
if(queue.size() >= MAX_COUNT) {
try {
System.err.println("篮子中苹果已经放满了,我好累啊,我等待.....");
lock.wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
}else {
queue.add(new Apple("xxxx"));
System.err.println("我要往篮子里面放置苹果了.... 现在有" + queue.size() +"个苹果");
lock.notifyAll();
}
}
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
public static void main(String[] args) {
for (int i = 0; i < 10; i++) {
Customer customer = new Customer();
customer.start();
}
Producer producer = new Producer();
producer.start();
}
}
输出结果:
我要往篮子里面放置苹果了.... 现在有1个苹果
篮子里面有苹果了,我要吃苹果.... 还剩下:0个苹果
篮子里面没有苹果了,我好饿啊,我等待....
篮子里面没有苹果了,我好饿啊,我等待....
篮子里面没有苹果了,我好饿啊,我等待....
篮子里面没有苹果了,我好饿啊,我等待....
篮子里面没有苹果了,我好饿啊,我等待....
我要往篮子里面放置苹果了.... 现在有1个苹果
篮子里面有苹果了,我要吃苹果.... 还剩下:0个苹果
篮子里面没有苹果了,我好饿啊,我等待....
篮子里面没有苹果了,我好饿啊,我等待....
篮子里面没有苹果了,我好饿啊,我等待....
篮子里面没有苹果了,我好饿啊,我等待....
篮子里面没有苹果了,我好饿啊,我等待....
我要往篮子里面放置苹果了.... 现在有1个苹果
篮子里面有苹果了,我要吃苹果.... 还剩下:0个苹果
篮子里面没有苹果了,我好饿啊,我等待....
篮子里面没有苹果了,我好饿啊,我等待....
篮子里面没有苹果了,我好饿啊,我等待....
篮子里面没有苹果了,我好饿啊,我等待....
篮子里面没有苹果了,我好饿啊,我等待....
篮子里面没有苹果了,我好饿啊,我等待....
篮子里面没有苹果了,我好饿啊,我等待....
篮子里面没有苹果了,我好饿啊,我等待....
篮子里面没有苹果了,我好饿啊,我等待....
篮子里面没有苹果了,我好饿啊,我等待....
我要往篮子里面放置苹果了.... 现在有1个苹果
篮子里面有苹果了,我要吃苹果.... 还剩下:0个苹果
我要往篮子里面放置苹果了.... 现在有1个苹果
篮子里面有苹果了,我要吃苹果.... 还剩下:0个苹果
篮子里面没有苹果了,我好饿啊,我等待....
篮子里面没有苹果了,我好饿啊,我等待....
篮子里面没有苹果了,我好饿啊,我等待....
篮子里面没有苹果了,我好饿啊,我等待....
篮子里面没有苹果了,我好饿啊,我等待....
篮子里面没有苹果了,我好饿啊,我等待....
篮子里面没有苹果了,我好饿啊,我等待....
篮子里面没有苹果了,我好饿啊,我等待....
对于上面的代码我们可以进行优化和不足之处,你看出哪里要进行优化吗?