java中的生产者和消费者的问题

1----使用Java.util.concurrent.locks包中的lock接口取代synchronized,通过ReentrantLock这个已经实现Lock接口的类,

创建ReentrantLock对象lock(private final ReentrantLock lock = new ReentrantLock(); ) ,并通过使用这个对象中的lock()方法让线程获得锁(lock.lock(););

使用unlock();在退出代码块块时释放锁(lock.unlock();),

2----其中while(flag)解决了if(flag)存在的重复生产,使得消费者丢失对其中被覆盖的数据(烧鸡)的读取.但是while会导致死锁,会出现全部线程都被休眠的情况,此时可以将notify ()修改为notifyAll()使得程序被全部唤醒,间接实现相互唤醒,但是由于对同类线程的唤醒时没有意义的,此时,程序的效率降低.

3---解决上一个问题的方法为:使用Java.util.concurrent.locks中的Condition接口,通过对同一个锁创建不同的Condition实例,并使用不同实例调用其各自的await()和signal()方法实现对t0 t1和t2 t3这2组线程的冻结和唤醒管理.从而不再需要每次都全部唤醒造成的效率降低的问题.

 1 /*
 2 需求:生产者---->消费者
 3 资源:烤鸭一只
 4      每生产一只,就消费一zhi
 5 */
 6 import java.util.concurrent.locks.*;
 7 class Resource
 8 {
 9     private String name;
10     private int count=0;
11     private boolean flag=false;
12     private final ReentrantLock lock = new ReentrantLock();
13     final Condition cond1  = lock.newCondition();
14     final Condition cond2  = lock.newCondition();
15     public  void make(String name)
16     {
17         lock.lock();
18         while(flag)
19             try
20             {
21                 cond1.await();
22             }
23             catch (InterruptedException e)
24             {
25             }
26
27         this.name = name;
28         count++;
29         flag=true;
30         cond2.signal();
31         System.out.println(Thread.currentThread().getName()+"生产者..."+name+count);
32         lock.unlock();
33     }
34     public void out()
35     {
36         lock.lock();
37         while(!flag)
38             try
39             {
40                 cond2.await();
41             }
42             catch (InterruptedException e)
43             {
44             }
45         System.out.println(Thread.currentThread().getName()+"消费者......."+count);
46         flag = false;
47         cond1.signal();
48         lock.unlock();
49     }
50
51 }
52 class Producer implements Runnable
53 {
54     Resource r = new Resource();
55     Producer(Resource r)
56     {
57         this.r = r;
58     }
59     public void run()
60     {
61         while(true)
62         r.make("烤鸭");
63     }
64 }
65 class Customer implements Runnable
66 {
67     Resource r = new Resource();
68     Customer(Resource r)
69     {
70         this.r = r;
71     }
72     public void run()
73     {
74         while(true)
75         r.out();
76     }
77 }
78 class ProducerCustomer
79 {
80     public static void main(String[] args)
81     {
82         //建立资源类
83          Resource r = new Resource();
84         //建立任务对象
85         Producer pro = new Producer(r);
86         Customer cus = new Customer(r);
87         //建立线程
88         Thread t0 = new Thread(pro);
89         Thread t1 = new Thread(pro);
90         Thread t2 = new Thread(cus);
91         Thread t3 = new Thread(cus);
92         //开启线程
93         t0.start();
94         t1.start();
95         t2.start();
96         t3.start();
97
98     }
99 }
时间: 2024-10-06 15:38:37

java中的生产者和消费者的问题的相关文章

Java中的生产者、消费者问题

Java中的生产者.消费者问题描述: 生产者-消费者(producer-consumer)问题, 也称作有界缓冲区(bounded-buffer)问题, 两个进程共享一个公共的固定大小的缓冲区(仓库). 其中一个是生产者, 用于将产品放入仓库: 另外一个是消费者, 用于从仓库中取出产品消费. 问题出现在当仓库已经满了, 而此时生产者还想向其中放入一个新的产品的情形, 其解决方法是让生产者此时进行等待, 等待消费者从仓库中取走了一个或者多个产品后再去唤醒它. 同样地, 当仓库已经空了, 而消费者还

Java多线程的生产者与消费者模型,线程间的通信

java多线程中的生产者与消费者模式:首先有一个阻塞队列,生产者将生产的东西放到队列里,消费者再从队列中取.当队列中的东西数量达到其容量就发生阻塞. import java.util.Random; import java.util.concurrent.ArrayBlockingQueue; import java.util.concurrent.BlockingQueue; import java.util.concurrent.LinkedBlockingQueue; import jav

java多线程中的生产者与消费者之等待唤醒机制@Version1.0

一.生产者消费者模式的学生类成员变量生产与消费demo,第一版1.等待唤醒:    Object类中提供了三个方法:    wait():等待    notify():唤醒单个线程    notifyAll():唤醒所有线程2.为什么这些方法不定义在Thread类中呢?  这些方法的调用必须通过锁对象调用,而我们刚才使用的锁对象是任意锁对象.  所以,这些方法必须定义在Object类中.3.当我们在使用多线程的时候有的时候需要,一条线程产生一个数据,另一条线程接着消费一个数据,一边生产一边消费,

java多线程实现生产者与消费者---经典问题

前几天老师领着学习了一下单线程和多线程的题目. 这里是操作系统中非常经典的题目,生产者和消费者的题,这里涉及的是仓库, 只有一个人(生产者或消费者)进入,另一个人只有等待. 这里的重点是关于传值的问题.一定要保持一致,不然,对于存和取 的对象,就可能出现多个. //========================================================================// 仓库类 //====================================

并发协作:多线程中的生产者与消费者模型

对于多线程程序来说,不管任何编程语言,生产者和消费者模型都是最经典的.就像学习每一门编程语言一样,Hello World!都是最经典的例子. 实际上,准确说应该是“生产者-消费者-仓储”模型,离开了仓储,生产者消费者模型就显得没有说服力了. 对于此模型,应该明确一下几点: 1.生产者仅仅在仓储未满时候生产,仓满则停止生产. 2.消费者仅仅在仓储有产品时候才能消费,仓空则等待. 3.当消费者发现仓储没产品可消费时候会通知生产者生产. 4.生产者在生产出可消费产品时候,应该通知等待的消费者去消费.

在并发编程中使用生产者和消费者模式能够解决绝大多数并发问题。该模式通过平衡生产线程和消费线程的工作能力来提高程序的整体处理数据的速度。

什么是生产者消费者模式 生产者消费者模式是通过一个容器来解决生产者和消费者的强耦合问题.生产者和消费者彼此之间不直接通讯,而通过阻塞队列来进行通讯,所以生产者生产完数据之后不用等待消费者处理,直接扔给阻塞队列,消费者不找生产者要数据,而是直接从阻塞队列里取,阻塞队列就相当于一个缓冲区,平衡了生产者和消费者的处理能力. 什么是生产者消费者模式 生产者消费者模式是通过一个容器来解决生产者和消费者的强耦合问题.生产者和消费者彼此之间不直接通讯,而通过阻塞队列来进行通讯,所以生产者生产完数据之后不用等待

Java并发协作——生产者、消费者模型

概述 对于多线程程序来说,生产者和消费者模型是非常经典的模型.更加准确的说,应该叫"生产者-消费者-仓库模型".离开了仓库,生产者.消费者就缺少了共用的存储空间,也就不存在并非协作的问题了. 示例 定义一个场景.一个仓库只允许存放10件商品,生产者每次可以向其中放入一个商品,消费者可以每次从其中取出一个商品.同时,需要注意以下4点: 1.  同一时间内只能有一个生产者生产,生产方法需要加锁synchronized. 2.  同一时间内只能有一个消费者消费,消费方法需要加锁synchro

Linux内核中实现生产者与消费者(避免无效唤醒)

本文关注的重点是,避免内核线程的无效唤醒,并且主要是关注消费者线程的设计. 因此,为了省事,这里关与生产者,消费者本身的处理流程可能不够严密. 1. 生产者 一个内核线程,每生产一个商品后,就唤醒消费者,然后自己睡眠1秒钟. 2. 消费者 一个内核线程,每当被唤醒后,就消费商品,然后进入睡眠. 对于消费者线程的这种设计,有几个好处:响应快,平时不占任何cpu. 但这种设计有一点要注意,那就是要避免线程的无效唤醒.如何实现,看看消费者线程的代码就知道了. /* * kernel programmi

java多线程中的生产者与消费者之等待唤醒机制@Version2.0

二.生产者消费者模式的学生类成员变量生产与消费demo, @Version2.0 在学生类中添加同步方法:synchronized get()消费者,synchronized set()生产者 最终版的代码中: 把student的成员变量给私有化了, 把设置和获取的功能给封装成了功能,并加了同步, 设置或者获取的线程里面只需要调用方法即可. 1.等待唤醒:    Object类中提供了三个方法:    wait():等待    notify():唤醒单个线程    notifyAll():唤醒所