zoukankan      html  css  js  c++  java
  • 生产者消费者模式-->管程法

    生产者消费者模式-->管程法

    public class TestPC {
        public static void main(String[] args) {
            SynContainer container = new SynContainer();
            new Productor(container).start();
            new Consumer(container).start();
        }
    }
    //生产者
    class Productor extends Thread{
        SynContainer synContainer;
        public Productor(SynContainer synContainer){
            this.synContainer = synContainer;
        }
    
        @Override
        public void run() {
            for (int i = 0; i < 100; i++) {
                synContainer.push(new Chicken(i));
                System.out.println("生产者生产了第" + 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().num +"只鸡");
            }
        }
    }
    //产品
    class Chicken{
        int num;//产品编号
    
        public Chicken(int num) {
            this.num = num;
        }
    }
    //缓冲区
    class SynContainer{
        //需要一个容器大小
        Chicken[] chickens = new Chicken[10];
        //容器大小
        int count = 0;
        //生产者放入产品
        public synchronized void push(Chicken chicken){
            //如果容器满了,等待消费
            if (count == chickens.length){
                //生产者等待
                try {
                    this.wait();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
            //如果没有满,就把产品丢进去
            chickens[count] = chicken;
            count++;
            //通知消费者可以消费
            this.notifyAll();
        }
        //消费者消费产品
        public synchronized Chicken pop(){
            if (count == 0){
                //通知生产者生产
                try {
                    this.wait();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
            count--;
            Chicken chicken = chickens[count];
            //通知生产者可以生产
            this.notifyAll();
            return chicken;
        }
    }
    
    • 生产者:负责生产数据的模块(可能是方法,对象,线程,进程)
    • 消费者:负责处理数据的模块(可能是方法,对象,线程,进程)
    • 缓冲区:消费者不能直接消费生产者的数据,消费者从缓冲区拿出数据
    刚刚参加工作,很有很多不懂不会的,发现错误,欢迎指正,谢谢!
  • 相关阅读:
    解耦和耦合
    python os.remove()方法
    python中split()、os.path.split()函数用法
    P7116-[NOIP2020]微信步数【数学】
    2021牛客OI赛前集训营-方格计数【计数,dp】
    2021牛客OI赛前集训营-树数树【树上启发式合并,堆】
    Ybtoj-排列计数【矩阵乘法,分块幂】
    P7888-「MCOI-06」Distinct Subsequences【dp】
    号爸十一集训 Logs
    数据结构 专项题解
  • 原文地址:https://www.cnblogs.com/xd-study/p/13195831.html
Copyright © 2011-2022 走看看