首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >java生产者消费者模式结束信号

java生产者消费者模式结束信号
EN

Stack Overflow用户
提问于 2013-05-13 10:39:29
回答 3查看 959关注 0票数 1

我有一个应用生产者-消费者设计模式的应用程序。它是用java编写的。简而言之,生产者将项目放在阻塞队列中,消费者从那里取出项目。消费者应该一直运行,直到生产者发出停止的信号。

将这个信号从生产者传递给消费者的最好的方式是什么?首席设计师说他希望保持生产者和消费者的分离,但除了在消费者线程池上调用一个方法之外,我没有看到其他任何方法。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2013-05-13 10:45:41

首席程序员是对的。保持它们的分离会导致高度解耦的代码,这是非常好的。

有几种方法可以做到这一点。其中一种叫“毒丸”。这就是它的工作原理--当消费者看到一个已知的项目时,他们会自杀或者采取另一个行动。

如果有多个消费者(您提到的是ThreadPool)或有界队列,这可能会很棘手。请在Joshua Bloch的Java Concurrency in Practice中查找这一点。他解释得最好。

票数 2
EN

Stack Overflow用户

发布于 2013-05-13 10:44:10

通过队列发送取消消息。您的消费者的run方法将如下所示

代码语言:javascript
复制
while(true) {
    Message message = queue.take();
    if(message == Message.Cancel) {
        queue.offer(message); // so that the other consumers can read the Cancel message
        break;
    }
}
票数 1
EN

Stack Overflow用户

发布于 2013-05-13 10:55:02

创建一个ConsumerHalter类。将希望从queue获取数据的所有使用者注册到ConsumerHalter类,并让生产者在ConsumerHalther类中触发halt事件。然后,ConsumerHalter类调用每个使用者的onStopConsuming()。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16514142

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档