Java多线程 生产者 消费者(转)

忘记哪转的了,对不起作者了。


/*
* Java 生产者-消费者案例框架
*“生产者-消费者”问题的含义是,
*系统中有很多生产者和消费者并
*发工作生产者负责生产资源,消费者消耗资源。
*当消费者消费资源时,如果资源不足,则需要等待,
*反之当生产者生产资源时,若资源已满,则也需要等待。
*另外同一时刻只能有一个生产者或消费者进行操作。
*/

//面包容器(资源)
class BreadContainer
{
// 容器的最大容量
public static final int maxNum = 300;

// 当前面包的数量
private int num;

// 无参构造器
public BreadContainer()
{
}

// 有参构造器
public BreadContainer(int num)
{
// 初始化面包数量
this.num = num;
}

// 制作面包的同步方法
public synchronized void produceBread(int produceNum, String ProducerSName)
{
// 测试是否可以生产面包
while (num + produceNum > maxNum)
{
// 面包充足,生产者等待
System.out.println(ProducerSName + "要生产" + produceNum + "个,当前" + num
+ "个,资源充足,不需要生产," + ProducerSName + "去等待!");
try
{
wait();
}
catch (Exception e)
{
e.printStackTrace();
}
}
// 满足条件后,生产者生产面包,刷新数量
num = num + produceNum;
System.out.println(ProducerSName + "生产了" + produceNum + "个,现在有" + num
+ "个。");
// 唤醒资源等待池中的所有线程
notifyAll();
}

public synchronized void consumeBread(int consumeNum, String ConsumerSName)
{
// 测试面包数量是否够消费
while (consumeNum > num)
{
// 不够数量,消费者等待
System.out.println(ConsumerSName + "要消费" + consumeNum + "个,由于现在只有"
+ num + "个," + ConsumerSName + "于是去等待!");
try
{
wait();
}
catch (Exception e)
{
e.printStackTrace();
}
}
// 数量充足,消费面包,刷新数量
num = num - consumeNum;
System.out.println(ConsumerSName + "消费了" + consumeNum + "个,现在还剩下" + num
+ "个");
// 唤醒资源等待池中的所有线程
this.notifyAll();
}
}

// 生产者类
class ProducerS extends Thread
{
// 记录该生产者一次生产的数量
private int produceNum;

// 生产者需要访问的面包容器资源
private BreadContainer bc;

// 无参构造器
public ProducerS()
{
}

// 有参构造器
public ProducerS(int produceNum, BreadContainer bc, String ProducerSName)
{
// 对线程进行初始化
this.produceNum = produceNum;
this.bc = bc;
this.setName(ProducerSName);
}

// 生产者的工作方法
public void run()
{
// 调用资源容器的同步方法生产资源
bc.produceBread(produceNum, this.getName());
}
}

// 消费者类
class ConsumerS extends Thread
{
// 记录该消费者一次消费的数量
private int consumeNum;

// 消费者需要访问的面包容器资源
private BreadContainer bc;

// 无参构造器
public ConsumerS()
{
}

// 有参构造器
public ConsumerS(int consumeNum, BreadContainer bc, String ConsumerSName)
{
// 对线程进行初始化
this.consumeNum = consumeNum;
this.bc = bc;
this.setName(ConsumerSName);
}

// 消费者的行为方法
public void run()
{
// 调用资源容器的同步方法生产资源
bc.consumeBread(consumeNum, this.getName());
}
}

public class Sample16_9
{
public static void main(String args[])
{
// 创建资源对象,初始面包有50个
BreadContainer bc = new BreadContainer(50);
// 创建对应的生产者和消费者
ProducerS p1 = new ProducerS(50, bc, "P1");
ProducerS p2 = new ProducerS(200, bc, "P2");
ProducerS p3 = new ProducerS(290, bc, "P3");
ConsumerS c1 = new ConsumerS(70, bc, "c1");
ConsumerS c2 = new ConsumerS(80, bc, "c2");
// 启动生产者消费者线程
c1.start();
c2.start();
p1.start();
p3.start();
p2.start();
}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值