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