通过wait和notify实现的生产者消费者demo

本文演示了使用Java的wait和notify机制实现生产者消费者模型的方法。该模型包含一个容量为150的缓冲区,通过多线程模拟多个生产者与消费者的交互过程。生产者线程负责生成产品并将它们放入缓冲区,而消费者线程则从缓冲区取出并消费这些产品。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Java代码 :
import java.util.ArrayList;
import java.util.List;
/**
* 通过wait和notify实现的生产者消费者demo
* User: zhangb
* Date: 12-12-1
* Time: 下午7:19
*/
public class ProducerAndCustomerDemo {
private static int capacity = 150;
private static List<String> basket = new ArrayList<String>(capacity);

public static void main(String[] args) {
// 多生产者与多消费者
int producerSize = 2;
Thread[] ps = new Thread[producerSize];
for (int i = 0, step = 500; i < producerSize; i ++) {
ps[i] = new Thread(new Producer((i) * step, (i+1) * step), "生产-->线程--" + (i+1));
ps[i].start();
}

int customerSize = 10;
Thread[] cs = new Thread[customerSize];
for (int i = 0; i < customerSize; i ++) {
cs[i] = new Thread(new Customer(), "消费线程--" + (i+1));
cs[i].start();
}

// 等待生产线程结束并中断消费线程
for (int i = 0; i < producerSize; i ++) {
try {
ps[i].join();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
for (int i = 0; i < customerSize; i ++) {
cs[i].interrupt();
}
}
static class Producer implements Runnable {
private int start;
private int end;

Producer(int start, int end) {
this.start = start;
this.end = end;
}

@Override
public void run() {
for (int i = start; i < end; i ++) {
synchronized (basket) {
try {
while (basket.size() == capacity) {
basket.wait();
}
String p = " PRO" + i;
System.out.println(Thread.currentThread().getName() + p);
basket.add(p);
basket.notifyAll();
Thread.yield(); // 让出当前线程的执行权,有利于看出交替线程运行的效果
} catch (InterruptedException e) {
e.printStackTrace();
break;
}
}
}
}
}
static class Customer implements Runnable {
@Override
public void run() {
while (true) {
synchronized (basket) {
try{
while (basket.size() == 0) {
basket.wait();
}
System.out.println(Thread.currentThread().getName() + basket.remove(0));
basket.notifyAll();
} catch (InterruptedException e) {
System.out.println(Thread.currentThread().getName() + "退出");
break;
}
}
}
}
}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值