我是一个绝对的Java初学者,并且一直致力于为自定义迭代器(用于链表)获取remove()。我一直在努力让这个工作起来。我的问题是没有删除迭代的项目。但是,当没有前一个元素时,该方法会(正确地)抛出IllegalState错误。
如果你们可以看一下它,并表明可能出现的问题,我将不胜感激,因为我不能自己解决这个问题,并尝试过各种各样的事情。 一个问题:我接下来在构造函数中设置的问题是什么?因为如果我不这样做,那么列表就不会被迭代了!
提前非常感谢你。
=============================================== =====================
public class CustListIterator<E> implements Iterator<E> {
private Node<E> head;
private Node<E> next;
private Node<E> prev;
private CustList<E> list;
public CustListIterator(CustList<E> list) {
this.list = list;
head = list.head;
next = head;
}
public boolean hasNext() {
return next != null;
}
public E next() {
if (!hasNext())
throw new NoSuchElementException ();
prev = next;
E element = next.element;
next = next.next;
return element;
}
public void remove() {
if(prev == null) {
throw new IllegalStateException();
}
else {
if(prev == head){
head = prev.next;
list.head = head;
}
next = prev.next;
prev = null;
list.listSize--;
}
}
=============================================== ==============================
的迭代
CustList<String> items = new CustList<String>();
items.add("aaaaaa");
items.add("bbbbb");
items.add("ccc");
items.add("dddddddd");
items.add("eeeeee");
System.out.println("List iterated:");
Iterator<String> it = items.iterator();
while (it.hasNext()) {
System.out.println(it.next());
it.remove();
}
System.out.println("Size: " + items.size());
=============================================== ==============================
然而仍然给出
List iterated:
aaaaaa
bbbbb
ccc
dddddddd
eeeeee
Size: 0