首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用ConcurrentLinkedQueue的ThreadPoolExecutor

使用ConcurrentLinkedQueue的ThreadPoolExecutor
EN

Stack Overflow用户
提问于 2015-01-07 23:53:25
回答 2查看 1.1K关注 0票数 0

是否可以将名为ConcurrentLinkedQueue的非阻塞队列传递给ThreadPoolExecutor而不是LinkedBlockingQueue(或任何其他阻塞队列)?

EN

回答 2

Stack Overflow用户

发布于 2015-01-08 00:22:36

不,文档(http://docs.oracle.com/javase/7/docs/api/java/util/concurrent/ThreadPoolExecutor.html)指出需要使用阻塞队列。

请参阅排队部分。

票数 0
EN

Stack Overflow用户

发布于 2015-01-08 00:59:01

正如antonis所说,您必须使用阻塞队列。这是因为当队列变空时,池必须阻塞并等待更多任务。开发人员利用了BlockingQueue,而不是在池执行器本身中重新实现这种阻塞逻辑。

但是,由于ConcurrentLinkedQueue实现了Collection,因此您可以这样做:

代码语言:javascript
复制
ConcurrentLinkedQueue<Thing> nonBlocking = new ConcurrentLinkedQueue<>();
// Do work, enqueue things
LinkedBlockingQueue<Thing> blocking = new LinkedBlockingQueue<>(nonBlocking);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27823287

复制
相关文章

相似问题

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