文章目录
- 1. 题目
- 2. 答案
1. 题目
生产者 (Productor) 将产品交给店员 (Clerk) ,而消费者 (Customer)从店员处取走产品,店员一次只能持有固定数量的产品 ( 比如 4 ),如果生产者试图生产更多的产品,店员会叫生产者停一下,如果店中有空位放产品了再通知生产者继续生产;如果店中没有产品了,店员会告诉消费者等一下,如果店中有产品了再通知消费者来取走产品。
这里可能出现两个问题:
生产者比消费者快时,消费者会漏掉一些数据没有取到。
消费者比生产者快时,消费者会取相同的数据。
2. 答案
package day15;
/**
* 生产者与消费者
* @author 14532
*
*/
public class Test3 {
public static void main(String[] args) {
Clerk c = new Clerk();
//消费时不生产,生产时不消费
//生产者
new Thread(new Runnable() {
@Override
public void run() {
synchronized (c) {
while(true) {//无限循环代表无限的生产次数
if(c.productNum == 0) {//产品数为0,开始生产
System.out.println("产品数为0,开始生产");
while(c.productNum < 4) {
c.productNum++;//增加产品
System.out.println("库存:" + c.productNum);
}
System.out.println("产品数为:" + c.productNum + ",结束生产");
c.notify();//唤醒消费者线程
}else {
try {
c.wait();//生产者线程等待
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
}
}, "生产者").start();
//消费者
new Thread(new Runnable() {
@Override
public void run() {
synchronized (c) {
while(true) {//无限循环代表无限的消费次数
if(c.productNum == 4) {//产品数为4,开始消费
System.out.println("产品数为4,开始消费");
while(c.productNum > 0) {
c.productNum--;//消费产品
System.out.println("库存:" + c.productNum);
}
System.out.println("产品数为:" + c.productNum + ",结束消费");
c.notify();//唤醒生产者线程
}else {
try {
c.wait();//消费者线程等待
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
}
}, "消费者").start();
}
}
class Clerk{
public static int productNum = 0;
}
运行结果: