Я пытаюсь запустить этот метод, чтобы вставить общее значение (EltType) в двухстороннюю очередь (deque), но я продолжаю получать исключение outOfBoundsException, которое я просто не могу понять. Кто-нибудь может помочь мне с этим? Это всего лишь выдержка из кода, но я думаю, что это может быть связано с этим!Проблема с двунаправленной очередью
private final int CAPACITY = 10;
private int capacity;
private int end;
private EltType deque[];
public ArrayBasedDeque() {
this.capacity = CAPACITY;
deque = (EltType[]) (new Object[capacity]);
}
public void insertFirst(EltType first) {
if(!isEmpty()) {
EltType[] tempArray;
tempArray = (EltType[]) new Object[CAPACITY+1];
for (int i=0;i<=deque.length;i++) {
tempArray[i+1] = deque[i];
}
deque = tempArray;
}
deque[0] = first;
}
public boolean isEmpty() {
boolean returned;
if (deque.length < 1) {
returned = true;
}else {
returned = false;
}
return returned;
}
Ошибка:
java.lang.ArrayIndexOutOfBoundsException: 10
at ArrayBasedDeque.insertFirst(ArrayBasedDeque.java:48)
at TestABD.main(TestABD.java:5)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at edu.rice.cs.drjava.model.compiler.JavacCompiler.runCommand(JavacCompiler.java:271)
Кроме того, я бы не рекомендовал иметь имена переменных, которые отличаются только их случаем. Это плохая практика, и вы можете видеть здесь почему. Я бы переименовал вашу константу в INITIAL_CAPACITY. – David