美文网首页
生产者消费者

生产者消费者

作者: 西三旗靓仔 | 来源:发表于2020-01-05 12:04 被阅读0次
package com.subject01;
 
import java.util.PriorityQueue;
 /**
   * 通过wait和notify 实现
   * 生产者-消费者模型:当队列满时,生产者需要等待队列有空间才能继续往里面放入商品,而在等待的期间内,
   *          生产者必须释放对临界资源(即队列)的占用权。因为生产者如果不释放对临界资源的占用权,
 *          那么消费者就无法消费队列中的商品,就不会让队列有空间,那么生产者就会一直无限等待下去。
 *          因此,一般情况下,当队列满时,会让生产者交出对临界资源的占用权,并进入挂起状态。
 *          然后等待消费者消费了商品,然后消费者通知生产者队列有空间了。
 *          同样地,当队列空时,消费者也必须等待,等待生产者通知它队列中有商品了。这种互相通信的过程就是线程间的协作。
 */
public class CusAndPro {
 
    private int queueSize = 10 ;
    private PriorityQueue<Integer> queue = new PriorityQueue<Integer>(queueSize);
     
    public static void main(String[] args) {
        CusAndPro cap = new CusAndPro();
        Consumer cus = cap.new Consumer();
        Producer pro = cap.new Producer();
        Thread cusT = new Thread(cus);
        Thread proT = new Thread(pro);
         
        proT.start();
        cusT.start();
    }
    /**
     * 消费者
     * com.subject01.CusAndPro.java
     * @author 孙涛
     * 2016年5月10日
     */
    class Consumer implements Runnable{
 
        @Override
        public void run() {
            cousume();
        }
 
        private void cousume() {
            while(true){
                synchronized (queue) {
                    while(queue.size() ==0){
                        try {
                            System.out.println("队列空,等待数据。。。");
                            queue.wait();
                        } catch (InterruptedException e) {
                            e.printStackTrace();
                            queue.notify();
                        }
                    }
                     
                    queue.poll() ;
                    queue.notify();
                    System.out.println("从队列中取走一个元素,队列中剩余"+queue.size()+"个");
                }
            }
        }
         
    }
    class Producer implements Runnable{
 
        @Override
        public void run() {
            produce();
        }
 
        private void produce() {
            while(true){
                synchronized(queue){
                    while(queue.size() == queueSize){
                        try {
                            System.out.println("队列已满,等待空余的空间");
                            queue.wait();
                        } catch (InterruptedException e) {
                            e.printStackTrace();
                            queue.notify();
                        }
                    }
                     
                    queue.offer(1);   // 每次插入一个元素
                    queue.notify();
                    System.out.println("向队列取中插入一个元素,队列剩余空间:"+(queueSize-queue.size()));
                }
            }
        }
         
    }
}

相关文章

  • Dubbo起步

    目录 定义接口 生产者生产者依赖生产者实现 消费者消费者依赖消费者实现 初步印象 定义接口 生产者 生产者依赖 生...

  • 生产者消费者(一)

    生产者消费者模型: 生产者------> 缓存<-------- 消费者

  • 生产者和消费者问题

    生产者和消费者问题 问题简述 组成 系统中有一组生产者和消费者进程 生产者生产者将产品放入缓冲区 消费者消费者进程...

  • 9. python多进程之Queue实现生产者消费者模型

    一、概述 什么是生产者消费者模式生产者消费者模式是通过一个容器来解决生产者和消费者的强耦合问题。生产者和消费者彼此...

  • 生产者消费者

    什么是生产者和消费者 生产者消费者模式是通过一个容器来解决生产者和消费者的强耦合问题。 生产者和消费者彼此之间不直...

  • java生产者消费者实现

    什么是生产者消费者模式 生产者消费者模式是通过一个容器来解决生产者和消费者的强耦合问题。生产者和消费者彼此之间不直...

  • 生产者消费者模式-java原生、Disruptor实现方案

    生产者消费者模式介绍 生产者消费者模式是通过一个容器来解决生产者和消费者的强耦合问题。生产者和消费者彼此之间不直接...

  • Java实现生产者-消费者模型的几种方法

    什么是生产者消费者模式 生产者消费者模式是通过一个容器来解决生产者和消费者的强耦合问题。生产者和消费者彼此之间不直...

  • 生产者和消费者模型

    生产者和消费者模型 1. 什么是生产者和消费者模型 生产者消费者模型具体来讲,就是在一个系统中,存在生产者和消费者...

  • 生产者消费者

    生产者/消费者模式(阻塞队列) 生产者消费者模型的实现

网友评论

      本文标题:生产者消费者

      本文链接:https://www.haomeiwen.com/subject/oubqactx.html