ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

多线程:一个生产者一个消费者

2021-12-04 17:59:42  阅读:124  来源: 互联网

标签:count hcq 消费者 生产者 public num println 多线程 包子


一个生产者一个消费者

管程法:消费者、生产者、被消费的对象(包子) 、缓冲区(包子铺)
1.被消费的对象(包子)

package com.mutouren.demo.ex;

/**
 * @author wrr
 * @date 2021/12/4 0004 14:38
 * @description TODO
 **/
public class Baozi {

    //包子的编号
    private int num;

    Baozi(int num){
        this.num=num;
    }


    public int getNum() {
        return num;
    }

    public void setNum(int num) {
        this.num = num;
    }
}

2.缓冲区(包子铺)

package com.mutouren.demo.ex;

/**
 * @author wrr
 * @date 2021/12/4 0004 14:35
 * @description 缓冲区  用来存放包子
 **/
public class Hcq {

    private Baozi[] baozis = new Baozi[10];

    private int count = 0;


    /**
     * 放包子
     **/
    public synchronized void pushBaozi(Baozi baozi) {
        //如果包子满了  等待消费者消费
        if (baozis.length == count) {
            //通知消费者消费
            try {
                System.out.println("生产者等待。。。。。");
                this.wait();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
        System.out.println("生产者开始放。。。。。");
        //如果包子没满  则放包子
        baozis[count] = baozi;
        count++;
        try {
            Thread.sleep(10);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.println(Thread.currentThread().getName() + "生产了第 " + baozi.getNum() + " 个包子");

        this.notifyAll();


    }


    /**
     * 吃包子
     **/
    public synchronized void eatBaozi() {
        //如果没有包子  等待生产者生产包子
        if (count == 0) {
            //通知消费者消费
            try {
                System.out.println("消费者等待。。。。");
                this.wait();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }

        //如果有  则进行消费
        System.out.println("消费者开始吃。。。。");
        count--;
        Baozi baozi = baozis[count];
//        System.out.println("count = " + count);
        try {
            Thread.sleep(10);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.println(Thread.currentThread().getName() + "消费了第 " + baozi.getNum() + " 个包子");

        this.notifyAll();

    }
}

3.生产者

package com.mutouren.demo.ex;

/**
 * @author wrr
 * @date 2021/12/4 0004 14:37
 * @description 生产者
 **/
public class Scz implements Runnable {

    //生产者消费者都要从缓冲区拿包子
    private Hcq hcq;

    Scz(Hcq hcq){
        this.hcq=hcq;
    }

    @Override
    public void run() {
        for (int i = 1; i <= 100; i++) {
            hcq.pushBaozi(new Baozi(i));
        }
    }
}

4.消费者

package com.mutouren.demo.ex;

/**
 * @author wrr
 * @date 2021/12/4 0004 14:37
 * @description 消费者
 **/
public class Xfz implements Runnable {

    private Hcq hcq;

    public Xfz(Hcq hcq) {
        this.hcq=hcq;
    }

    @Override
    public void run() {
        for (int i = 0; i < 100; i++) {
            hcq.eatBaozi();
        }
    }
}

5.主类

package com.mutouren.demo.ex;

/**
 * @author wrr
 * @date 2021/12/4 0004 14:58
 * @description TODO
 **/
public class Test {

    public static void main(String[] args) {
        Hcq hcq = new Hcq();
        Scz scz = new Scz(hcq);
        Xfz xfz = new Xfz(hcq);
        new Thread(xfz,"消费者1").start();
        new Thread(scz,"生产者1111").start();

    }
}

结果:
在这里插入图片描述

总结:
1.黄色的框说明 wait会释放锁并且在再次得到锁之后 会继续从原来的地方执行,而不是从头开始
2.结果说明了 是先生产后消费的

标签:count,hcq,消费者,生产者,public,num,println,多线程,包子
来源: https://blog.csdn.net/Maspue/article/details/121719151

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有