创建四个类
1.面包类 锅里只可以放10个面包 ---装面包的容器
2.厨房 kitchen 生产面包 和消费面包  最多生产100个面包
3.生产者
4消费者
5.测试类

多线程经典案例

import java.util.Stack;

//生产者消费者 问题 面包类
public class Brake {
    //做面包的锅 最多十个面包
    public static final int MAX_NUMBER=10;
    Stack<Integer> stack=new Stack<Integer>();
    public static int BRAKE_NUM=0; //面包的个数
    
    //做面包
    public synchronized  void insert(int number)
    {
        stack.push(number);
        Brake.BRAKE_NUM++;//锅里面包数+1
    }
    
    //拿面包
    public synchronized int remove()
    {
        
        Brake.BRAKE_NUM--;
        return stack.pop(); //出栈
    }
}
-------------------------------------------------------------

厨房类

public class Kitchen {
    private Brake brake;
    public  static int bigNumber = 0;///大林吃的数量
    public static int smallNumber = 0;
    public static int TOTAL_NUMBER = 100;//做面包的总数
    public static int iCount=1; //计数器  统计
    
    public Kitchen(Brake brake)
    {
        this.brake=brake;
    }
    
    //做面包的方法
    public synchronized void make()
    {
        //判断锅是否已满
        if(Brake.BRAKE_NUM<10)
        {
            brake.insert(Kitchen.iCount);
            System.out.println("妈妈做完了第"+Kitchen.iCount+"个面包");
            Kitchen.iCount++;
            notifyAll();//唤醒2个儿子吃面包
        }
        else
        {
            System.out.println("锅已经有10个面包,等待儿子吃面包");
            try
            {
                wait();
            }
            catch(Exception ex)
            {
                ex.printStackTrace();
            }
        }
    }

//吃面包的方法
    public  synchronized void eat()
    {
        //判断锅里是否为空
        if(Brake.BRAKE_NUM>0)
        {
            int temp=brake.remove();//获得吃掉面包的编号
            System.out.println(Thread.currentThread().getName()+"吃掉了第"+temp+"个面包");
        if(Thread.currentThread().getName().equals("大林"))
        {
            bigNumber++;
        }
        else
        {
            smallNumber++;
        }
        notifyAll();//唤醒妈妈继续做面包
        }
        else
        {
            System.out.println("面包吃完了 等待妈妈做面包");
            try
            {
                wait();
            }
            catch(Exception ex)
            {
                ex.printStackTrace();
            }
        }
    }
}
------------------------------------------------------------------

//生产者类
public class Productor implements Runnable{
    private Kitchen kitchen;
    public Productor(Kitchen kitchen)
    {
        this.kitchen=kitchen;
    }
    @Override
    public void run() {
        while(true)
        {
            if(Kitchen.iCount>100)//一百个面包做完
            {
                break;                
            }else
            {
                try {
                    kitchen.make();//妈妈不断做面包
                    Thread.sleep(150);
                } catch (Exception e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
            }        
        }
        System.out.println("100个面包做完了");
    }
    
}

---------------------------------------------------------------

//定义消费者类
public class Consumer implements Runnable{
    private Kitchen kitchen;
    public Consumer(Kitchen kitchen)
    {
        this.kitchen=kitchen;
    }
    @Override
    public void run() {
        while(true)
        {
            //如何结束消费者线程
            if(Kitchen.iCount>100&&Brake.BRAKE_NUM<=0)
            {
                break;
            }else
            {
                try {
                    kitchen.eat();
                    Thread.sleep(100);
                } catch (Exception e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
            }
        }        
    }
}
----------------------------------------------------------------------------------------------

//生产者消费者问题  java多线程实例项目
public class TestBrake {
    public static void main(String[] args) {
        Brake brake=new Brake();
        Kitchen kitchen=new Kitchen(brake);
        Productor p=new Productor(kitchen);
        Consumer c1=new Consumer(kitchen);
        Consumer c2=new Consumer(kitchen);
        //妈妈线程
        Thread mother=new Thread(p,"妈妈");
        Thread bigSon=new Thread(c1,"大林");
        Thread smallSon=new Thread(c1,"小林");
        mother.start();
        bigSon.start();
        smallSon.start();
        
        try {
            mother.join();
            bigSon.join();
            smallSon.join();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.println("大林吃了:"+Kitchen.bigNumber+"个面包");
        System.out.println("小林吃了:"+Kitchen.smallNumber+"个面包");

}
}

JAVA多线程之生产者 消费者模式 妈妈做面包案例的更多相关文章

  1. Java多线程_生产者消费者模式2

    在我的上一条博客中,已经介绍到了多线程的经典案列——生产者消费者模式,但是在上篇中用的是传统的麻烦的非阻塞队列实现的.在这篇博客中我将介绍另一种方式就是:用阻塞队列完成生产者消费者模式,可以使用多种阻 ...

  2. Java多线程-----实现生产者消费者模式的几种方式

       1 生产者消费者模式概述 生产者消费者模式就是通过一个容器来解决生产者和消费者的强耦合问题.生产者和消费者彼此之间不直接通讯,而通过阻塞队列来进行通讯,所以生产者生产完数据之后不用等待消费者处理 ...

  3. 【多线程】java多线程实现生产者消费者模式

    思考问题: 1.为什么用wait()+notify()实现生产者消费者模式? wait()方法可以暂停线程,并释放对象锁 notify()方法可以唤醒需要该对象锁的其他线程,并在执行完后续步骤,到了s ...

  4. Java多线程编程——生产者-消费者模式(1)

    生产者-消费者模式在生活中非常常见.就拿我们去餐馆吃饭为例.我们会遇到以下两种情况: 1.厨师-客人 如下图所示,生产者.消费者直接进行交互. 生产者生产出产品后,通知消费者:消费者消费后,通知生产者 ...

  5. Java多线程_生产者消费者模式1

    生产者消费者模型       具体来讲,就是在一个系统中,存在生产者和消费者两种角色,他们通过内存缓冲区进行通信,生产者生产消费者需要的资料,消费者把资料做成产品.生产消费者模式如下图.(图片来自网络 ...

  6. Java设计模式之生产者消费者模式

    Java设计模式之生产者消费者模式 博客分类: 设计模式 设计模式Java多线程编程thread 转载 对于多线程程序来说,不管任何编程语言,生产者和消费者模型都是最经典的.就像学习每一门编程语言一 ...

  7. java多线程解决生产者消费者问题

    import java.util.ArrayList; import java.util.List; /** * Created by ccc on 16-4-27. */ public class ...

  8. 【多线程】--生产者消费者模式--Lock版本

    在JDK1.5发布后,提供了Synchronized的更优解决方案:Lock 和 Condition 我们使用这些新知识,来改进例子:[多线程]--生产者消费者模式--Synchronized版本 改 ...

  9. java多线程模拟生产者消费者问题,公司面试常常问的题。。。

    package com.cn.test3; //java多线程模拟生产者消费者问题 //ProducerConsumer是主类,Producer生产者,Consumer消费者,Product产品 // ...

随机推荐

  1. Go包管理go mod使用

    Go Modules介绍 为了解决Go包管理的问题,Go从1.11开始加入了Go Modules这一新特性.让包的依赖和版本管理更加容易. 一个module可以理解为一个单独的包或者模块,module ...

  2. jsp中获取路径信息的方法

    今天在看代码时,发现程序使用了 request.getScheme() .不明白是什么意思,查了一下.结果整理如下: 1.request.getScheme() 返回当前链接使用的协议:一般应用返回h ...

  3. toad for oracle 小技巧

    在SQL*LOADER 工具上(或者称为SQLLDR,读为:“sequel loader”),因为它仍然是装载数据的主要方法,SQLLDR 能够在极短的时间内装 载庞大数量的数据. 我也是初使用,理解 ...

  4. T133309 57级返校测试重测-T2-选票统计

    大致题意: 找出个数超过n/4的数们. 基本思路: 一开始我是用map做的,然后就很玄学的TLE了. 啊,那就换个法吧. 先排个序,然后一样的数就在一起了, 再然后直接从前往后遍历一下,就能得出结果了 ...

  5. 不知道Linux内核到底长啥样?这幅漫画让你秒懂!

    下面给大家分享一个[超全2020Linux学习教程],点击链接免费领取哦~ https://www.magedu.com/?p=84301&preview=true

  6. 利用Serverless应用搭建Hexo博客

    本文将介绍如何使用火爆的Serverless应用,15分钟快速搭建Hexo博客.以腾讯云提供的Serverless应用–云开发为例: 步骤1:安装 CloudBase CLI 以及本地部署 Hexo ...

  7. 回文树(回文自动机)(PAM)

    第一个能看懂的论文:国家集训队2017论文集 这是我第一个自己理解的自动机(AC自动机不懂KMP硬背,SAM看不懂一堆引理定理硬背) 参考文献:2017国家集训队论文集 回文树及其应用 翁文涛 参考博 ...

  8. 橘子origin游戏平台如何绑定登陆验证/二次验证码?

    任天堂游戏公司4月份16万用户数据被黑客盗取,官方呼吁用户绑定二次验证码.疫情期间游戏用户暴涨,黑客活动频率也在增长,想起R星俱乐部用户绑定两步验证给十金的长期活动实在是明智之举,下面说下橘子游戏平台 ...

  9. 【Go语言学习】匿名函数与闭包

    前言 入坑 Go 语言已经大半年了,却没有写过一篇像样的技术文章,每次写一半就搁笔,然后就烂尾了. 几经思考,痛定思痛,决定金盆洗手,重新做人,哦不,重新开始写技术博文. 这段时间在研究Go语言闭包的 ...

  10. Python break语句

    Python break语句:当运行到 break 语句时,终止包含 break 的循环语句. 注:无论判断条件是否达到 False 或 序列是否遍历完都会停止执行循环语句和该 break 下的所有语 ...