/*
- num 库存变量,p 生产变量/消费变量
- 生产者最多库存100个产品
- 生产者将随机生产0~100个产品
- 当 (新生产产品p+库存num)>100时,先产满100个,再将先前计划p超出库存的生产出来
- 消费者将随机消费0~100个产品
- 本代码在java运行环境下运行
- *该代码运行一段时间后要手动停止,否则会一直运行
*/
//主函数
public class ProductAndCustorm {
public static void main(String[] args) {
Product pro = new Product();
Producer producer = new Producer(pro);
Customer customer = new Customer(pro);
producer.start(); //开启生产者线程
customer.start(); //开启消费者线程
}
}
//以下是产品类,生产者类,消费者类
//产品
class Product {
int num = 0;
//生产者生产
public synchronized void add(int p) throws Exception {
while ((num + p) > 100) {
System.out.println("将生产" + p + "个产品,现有" + num + "个产品,等待消费");
p = num + p - 100; //超出库存的计划生产的产品个数
System.out.println("先生产" + (100 - num) + "个产品,原有" + num + "个产品");
num = 100; //库存产满100
System.out.println("生产产品满" + num);
notifyAll(); // 唤醒生产者等待线程
this.wait(); // 库存已满,生产者线程等待
System.out.println("再将生产" + p + "个产品,现有" + num + "个产品");
}
num += p;
System.out.println("生产者生产了" + p + "个产品,现有" + num + "个产品.");
this.notifyAll();
Thread.sleep(200);
}
//消费者消费
public synchronized void cost(int p) throws Exception {
while (p > num) {
System.out.println("\t将消费" + p + "个产品,等待生产");
this.wait();
}
num -= p;
System.out.println("\t消费者消费了" + p + "个产品,现有" + num + "个产品.");
this.notifyAll();
Thread.sleep(200);
}
}
//生产者
class Producer extends Thread {
Product pro;
public Producer(Product pro) {
this.pro = pro;
}
public void run() {
while (true) {
int p = (int) (Math.random() * 99+1); //产生0~100随机数
try {
pro.add(p); //生产者生产
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
//消费者
class Customer extends Thread {
Product pro;
public Customer(Product pro) {
this.pro = pro;
}
public void run() {
while (true) {
int p = (int) (Math.random() * 99 + 1);
try {
pro.cost(p);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
Eclipse下运行结果: