0

由于 ArrayDeque 类实现了 Deque 并且没有任何容量限制。addFirst()像,addLast()等抛出异常的方法的目的是什么?它会在任何情况下添加元素,因为数组没有边界。有人可以解释一下我们可以在try{}catch{}块内使用的实现以及 addFirst 可能引发异常的场景吗?

try{ArrayDeque adObj = new ArrayDeque();
adObj.addFirst("Oracle");//we can keep on adding first. Use to exception handling?
}catch(Exception e){
}
4

4 回答 4

1

ArrayDequeue.addFirst()记录在案的唯一异常是NullPointerException. 由于这是一个未经检查的异常,因此您不需要那个 catch 块。

于 2011-04-11T12:11:30.070 回答
1

ArrayDeque确实存在潜在的容量问题,这意味着它可能会抛出。每次扩展它都会使容量增加一倍,因此最终它不能再增加一倍。代码的一种实现执行以下操作:

private void doubleCapacity() {
    int n = elements.length;
    int newCapacity = n << 1;
    if (newCapacity < 0)
        throw new IllegalStateException("Sorry, deque too big");
}

通过如下定义,addFirst该方法可以抛出至少两个接口文档中描述的异常。

public void addFirst(E e) {
    if (e == null)
        throw new NullPointerException();
    elements[head = (head - 1) & (elements.length - 1)] = e;
    if (head == tail)
        doubleCapacity();
}

正如其他人提到的那样,接口上的 JavaDoc 只是给出了可能的例外。它抛出的所有类型都不是已检查异常,因此您不必被迫捕获它们。

于 2011-04-11T12:12:52.043 回答
0

一些实现Deque是受限的(即容量有限),有些则不是。如果已达到限制,则抛出诸如addFirstthrow 之类的方法。IllegalStateException其他方法,例如offerFirst返回一个布尔值来指示相同的结果。

如果您不想处理潜在的异常,或者知道不会有任何异常,只需使用offerFirst并忽略结果。

于 2011-04-11T12:13:31.937 回答
0

Deque抛出AIllegalStateException是因为 Java 允许您使用不同的或创建自己的实现Deque,这可能有大小限制。 ArrayDeque不会抛出这些异常,所以如果您绝对确定您的代码将使用ArrayDeque它们,那么就这样声明它们并且它们不会抛出IllegalStateException

于 2011-04-11T12:16:35.533 回答