Java基础语法-管程法(多线程)

生产者消费者问题利用缓冲区解决:


1.首先需要四个角色 :1.生产者2.消费者3.缓冲区4.商品。


2.生产者生产商品放到缓冲区,缓冲区如果满了,生产者停止运作,进入等待。


3.消费者从缓冲区拿商品,如果缓冲区商品没有了,先唤醒生产者,然后进入等待。

示例如下:

/**
 * @ClassName TubeMethodTest
 * @Description 生产者消费者问题解决办法-管程法
 * @Author
 * @Date 2020-05-25 14:12
 * @Version 1.0
 **/
public class TubeMethodTest {
    public static void main(String[] args) {
        SynContainer synContainer = new SynContainer();
        new Productor(synContainer).start();
        new Consumer(synContainer).start();
    }
}
//生产者
class Productor extends Thread{
    SynContainer container;
    public Productor(SynContainer container){
        this.container = container;
    }

    @Override
    public void run() {
        for (int i = 0; i < 100; i++) {
            container.push(new Googs(i));
            System.out.println("生产了"+i+"个商品");
        }
    }
}
//消费者
class Consumer extends Thread{
    SynContainer container;
    public Consumer(SynContainer container){
        this.container = container;
    }
    @Override
    public void run() {
        for (int i = 0; i < 100; i++) {
            System.out.println("消费了第"+container.pop().id+"个商品");
        }
    }
}
//商品
class Googs{
    int id;
    Googs(int id){
        this.id = id;
    }
}
//缓冲区
class SynContainer{

    //设置一个容器大小
    Googs[] googs = new Googs[10];
    //设置容器计数器
    int count = 0;

    //生产者放入产品
    public synchronized void push(Googs goog){
        //如果容器满了,就需要等待消费者消费
        if(count == googs.length){
            //通知消费者消费,生产者等待
            try {
                this.wait();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
        //如果容器未满,放入商品
        googs[count] = goog;
        count++;
        //可以通知消费者消费了
        this.notifyAll();
    }
    //消费者消费产品
    public synchronized Googs pop(){
        //判断能否消费
        if(count == 0){
            //等待生产者生产
            try {
                this.wait();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
        //如果可以消费
        count--;
        Googs goog = googs[count];
        //消费完了通知生产者生产
        this.notifyAll();
        return goog;
    }
}

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值