多线程小案例:生产者与消费者之wait实现原理

题目要求

实现生产者生产,消费者消费的小demo

要求

生产者生产完成后,消费者才得以消费。生产者边生产,消费者边消费。
以卖包子为例,只有当包子生产出来,消费者才可以购买。并给予相应的提示

实例分析

根据要求,我们需要将生产者和消费者建立联系,并且二者相互提示。所以我们要把包子类,作为两者的连接桥梁。
由此可得,我们要创建三个实体类和一个测试类。将生产者和消费者分别作为一个线程进行测试。并且充分运用多线程的 wait() 和notify() 类进行提示

代码实现

  1. 包子类—
     class Baozi{

    String pier;   //包子皮儿
    String xieer;   //包子馅儿
    boolean flag=false;   //定义布尔类型,判断包子是否生产
}
  1. 消费者
   class Consumer implements Runnable{
   
    private Baozi baozi;

    private Object lock;

    public Consumer(Baozi baozi,Object lock) {
        this.baozi = baozi;
        this.lock=lock;
    }

    @Override
    public void run() {

        while (true){

            synchronized (lock){

                //如果baozi还没有生产好 那么线程开始等待
                if(!this.baozi.flag){
                    try {
                        System.out.println("消费者说包子还没有生产好 开始等待");
                        lock.wait();//开始等待
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }

                System.out.println("消费者开始吃包子");
                System.out.println("包子馅儿"+this.baozi.xieer+",皮儿"+this.baozi.pier);
                this.baozi.flag=false;

                lock.notify();//通知生产者线程生产
            }

        }

    }
}
  1. 生产者
 class Producer implements Runnable{

    private Baozi baozi;

    private Object lock;

    public Producer(Baozi baozi,Object lock) {
        this.baozi = baozi;
        this.lock=lock;
    }

    @Override
    public void run() {

        while (true){
            synchronized (lock){
                if(this.baozi.flag){
                    try {
                        lock.wait();//包子已经生产好了  所以开始等待
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
                this.baozi.xieer="杏仁";
                this.baozi.pier="大麦";
                this.baozi.flag=true;
                System.out.println("生产者生产好包子,皮儿"+this.baozi.pier+",馅儿"+this.baozi.xieer);
                lock.notify();//通知消费者线程开始吃包子了
            }
        }
    }
}
  1. 测试类
 public static void main(String[] args) {

        Baozi baozi = new Baozi();
        Object lock = new Object();

        new Thread(new Consumer(baozi, lock)).start();
        new Thread(new Producer(baozi, lock)).start();

    }

wait()方法的实现原理

正常情况下

假如存在四个线程 t1,t2,t3,t4,当程序运行时,这些线程会进行资源抢占,其中一个线程t1进入到锁对象中,其他线程就会在阻塞队列中进行等待,当T1 线程执行完毕后,T1线程也会进入到阻塞队列中,再次进行新一轮的资源抢占。
在这里插入图片描述

进行wait() 类时

开始也是进行相同的资源抢占,当T1 线程进入锁对象之后,T1线程继续执行,当执行wait() 方法后,T1对象停止当前代码,进入该对象的wait() 集合中并会释放锁,之后的代码将不再执行,进行等待。只有当出现某个持有相同锁的线程调用了notify() 方法后,才会重新进入到阻塞队列(重新争抢锁 继续执行)
在这里插入图片描述
在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值