生产者消费者设计图案是一个经典的并发或线程模式这降低之间的耦合
生产者和消费者通过与执行工作离作业的鉴定。在生产者的消费者设计模式共享队列是用来控制流和这种分离允许你单独编码生产者和消费者。它还涉及不同的时序问题需要生产项目或消费项目。用制片人的消费模式既是生产者又是消费者线程可以用不同的转速下工作。在这篇文章中,我们将看到什么是生产者消费者问题,这是非常流行的多线程的面试问题,如何使用阻塞队列和生产者利用消费者设计模式的优点来解决生产者消费者问题。
生产者消费者设计模式的现实世界的例子
生产者消费者模式是在现实生活中的每一个地方和描绘的协调和合作。就像一个人准备食物(监制),而另一种是提供食品(消费者),都将使用共享的表为把食品盘子和进食板。制片人是准备食物会等待,如果这个人表已满和消费者(人谁是服务食品)会等待,如果表是空的。表是一个共享这里对象。在Java库执行人框架本身实现生产者消费者设计模式来分离添加和任务的执行的责任。
生产者消费者模式的好处
它的确是一个有用的设计模式,并同时编写多线程并发或代码最为常用。这里
少其好处:
1)生产者消费者模式简单的开发。您可以独立或并行代码生产者和消费者,他们只需要知道共享对象。
2)生产者并不需要知道谁是消费者还是多少消费者那里。同样是消费者真实的。
3)生产者和消费者可以用不同的转速下工作。没有消费半生不熟的项目消费者的风险。
事实上通过监控用户的速度可以更好地利用引进更多的消费者。
4)分离生产者和消费者的功能结果在更清洁的,可读和可管理的代码。
### 生产者消费者问题在多线程
生产者-消费者问题是一个LSO一个流行的Java面试问题,其中面试官问到落实生产者消费者设计模式,使生产者应等待,如果队列或桶满和消费者应该等待,如果队列或
桶是空的。这个问题可以实现或Java中不同的方式解决的,经典的方法是使用wait和notify方法之间的沟通生产者和消费者线程和阻止他们每个人喜欢上队列满和空队列个别情况。随着引进的BlockingQueue在Java中的数据结构5它现在简单得多,因为BlockingQueue的引入隐式地提供这种控制封锁方式把(),并采取()。现在你不需要使用的等待,并通知生产者和消费者之间的沟通。的BlockingQueue put()方法将阻塞如果队列是满有界队列的情况下,采取()将阻止如果队列是空的。在下一节我们将看到一个生产者消费者设计模式的代码示例。
使用阻塞队列来实现生产者消费者模式
BlockingQueue的惊人提供outofbox支持阻塞放的简化了实施生产者-消费者设计模式(),并采取()。开发者不需要写混乱和关键件的等待,通知代码来实现通信。BlockingQuue是一个接口和Java 5提供了不同的植入等ArrayBlockingQueue和的LinkedBlockingQueue,都实现FIFO的顺序或元件,而ArrayLinkedQueue被在性质上有界的LinkedBlockingQueue任选限定。这里是一个完整的生产消费模式的代码示例与BlockingQueue的。与经典的比较它等待通知代码,它更简单,易于理解。
你看生产者线程生产数量和消费线程消耗它以FIFO的顺序,因为阻塞队列允许FIFO被访问的元素。
这是所有关于如何使用阻塞队列来解决生产者消费者问题或例如生产者消费者设计模式。我相信它远比等待通知的例子,但与这两个如果你要对任何Java面试的面试可能会问你两个方法准备好。
参考文献
聊聊并发——生产者消费者模式
http://www.infoq.com/cn/articles/producers-and-consumers-mode/#
网友评论