生产者消费者问题

 

package com.kuang.Demo10生产者管理者;
//测试:生产者消费者模型-->利用缓冲区解决:管程法
//生产者 , 消费者 , 产品 ,缓冲区
public class TestPC {
//    主线程
public static void main(String[] args) {
    SynContainer synContainer = new SynContainer();
    new Productor(synContainer).start();
    new Consumer(synContainer).start();
}


}
//生产者
class Productor extends Thread{
    SynContainer synContainer;
    //通过构造器把 容器的对象赋予给Productor对象 productor对象就可以使用容器的方法了
    public Productor(SynContainer synContainer){
        this.synContainer=synContainer;
    }
    
//  生产者和消费者都是通过线程并发运行的!
//  所以要重写run方法
    @Override
    public void run() {
        for (int i = 0; i < 100; i++) {
            System.out.println("生产了"+i+"只鸡");
            synContainer.push(new Chicken(i));
        }
    }
}
//消费者
class Consumer extends Thread{
    SynContainer synContainer;
    public Consumer(SynContainer synContainer){
        this.synContainer=synContainer;
    }
//消费
    @Override
    public void run() {
        for (int i = 0; i < 100; i++) {
            System.out.println("消费了-->"+synContainer.pop().id+"只鸡");
        }
    }
}




//产品
class Chicken{
    int id;
    public Chicken(int id){
        this.id=id;
    }
}

//缓冲区
class SynContainer{
    //需要一个容器大小 ,保存的是一个一个的对象
    Chicken[] chickens=new Chicken[10];
//  设置一个容器计数器
    int count=0;
    //生产者放入产品 ,涉及到并发 所以需要同步synchronized
    public synchronized void push(Chicken chicken) {
          if (count==chickens.length){
         //如果满了,通知消费者消费,生产等待
            try {
                this.wait();
            } catch (Exception e) {
                e.printStackTrace();
            }
          }
        //如果没满,我们就要丢入产品,队列指针思想,先赋值,指针加一,  弹出:先指针减一在弹出
        chickens[count]=chicken;
          count++;
          //通知消费者消费了
          this.notify();
    }



    //消费者拿走产品
    public synchronized Chicken pop(){
        //判断能否消费
        if (count==0){
            //如果不能消费,等待生产者生产,消费者等待
            try {
                this.wait();
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
        //如果可以消费
       count--;
//        把鸡拿出来,拿一个对象装住。
        Chicken chicken=chickens[count];
        //吃完了,通知生产者生产
        this.notify();
        return chicken;
    }

}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值