作者热门文章
- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
PriorityBlockingQueue
是无界的,但我需要以某种方式对其进行绑定(bind)。实现这一目标的最佳方法是什么?
有关信息,有界 PriorityBlockingQueue
将在 ThreadPoolExecutor
中使用。
注意:通过 bounded 我不想在发生这种情况时抛出 Exception,我想将对象放入队列中,然后根据其优先级值对其进行切割。有没有什么好的方法可以做到这一点?
最佳答案
我实际上不会将它子类化。虽然我现在无法将示例代码放在一起,但我建议使用装饰器模式的一个版本。
创建一个新类并实现您感兴趣的类实现的接口(interface):PriorityBlockingQueue .我发现此类使用了以下接口(interface):
Serializable, Iterable<E>, Collection<E>, BlockingQueue<E>, Queue<E>
在类的构造函数中,接受 PriorityBlockingQueue
作为构造函数参数。
然后通过PriorityblockingQueue
的实例实现接口(interface)所需的所有方法。添加使其有界所需的任何代码。这是装饰器模式的一个相当标准的实现。
关于java - 有界优先级阻塞队列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2341615/
我是一名优秀的程序员,十分优秀!