如果试图向阻塞队列添加超过阻塞队列剩余大小的集合,那么应该发生什么情况?从我到目前为止所读到的文档来看,这一点并不清楚。
LinkedBlockingQueue<Integer> foo = new LinkedBlockingQueue<Integer>(3);
foo.add(1);
foo.add(2);
LinkedBlockingQueue<Integer> tenElements = new LinkedBlockingQueue<Integer(10);
for(int i = 0; i < 10; i++)
tenElements.add(i);
foo.addAll(collectionWith10elements);发布于 2019-12-24 20:39:33
add()的文档声明,如果队列已满,则抛出IllegalStateException:
如果可以在不违反容量限制的情况下立即将指定的元素插入到此队列中,则在成功时返回
true,如果当前没有可用的空间,则会抛出IllegalStateException。
在尝试以下代码时:
public static void main(String[] args) throws Exception {
ArrayList<Integer> l = new ArrayList<Integer>();
l.add(10);
l.add(20);
l.add(30);
l.add(40);
l.add(50);
LinkedBlockingQueue<Integer> foo = new LinkedBlockingQueue<Integer>(3);
foo.add(1);
foo.add(2);
foo.addAll(l);
}您将得到以下异常:
Exception in thread "main" java.lang.IllegalStateException: Queue full
at java.util.AbstractQueue.add(AbstractQueue.java:98)
at java.util.AbstractQueue.addAll(AbstractQueue.java:187)
at Test.main(Test.java:16)发布于 2019-12-24 20:35:37
队列中持久化的元素应在达到容量后使用,否则我们将得到以下异常:-
Exception in thread "main" java.lang.IllegalStateException: Queue full
at java.util.AbstractQueue.add(AbstractQueue.java:98)
at java.util.AbstractQueue.addAll(AbstractQueue.java:187)发布于 2019-12-24 20:42:35
我在我的IDE上测试了它
Exception in thread "main" java.lang.IllegalStateException: Queue full
at java.util.AbstractQueue.add(AbstractQueue.java:98)
at java.util.AbstractQueue.addAll(AbstractQueue.java:187)如果你想学更多,去这里吧。
https://stackoverflow.com/questions/59473123
复制相似问题