这是我刚刚编写的代码的一部分。基本上,该类Document
实现了Iterable
接口。迭代器将像链表一样遍历节点。在remove
方法中,我使用了nodeMap
在Document
类范围内的引用。但是this
引用应该引用它Iterator
本身,那么它怎么会找到那个对象呢?或者是Iterator
一个子类Document
?
我以前没有想过这个问题。一下子就把自己弄糊涂了。
public class Document implements Iterable<DocumentNode> {
Map<Integer, DocumentNode> nodeMap;
public Iterator<DocumentNode> iterator() {
return new Iterator<DocumentNode>() {
DocumentNode node = nodeMap.get(0);
@Override
public boolean hasNext() {
return node != null && node.next != null;
}
@Override
public DocumentNode next() {
if (node == null) {
throw new IndexOutOfBoundsException();
}
return node.next;
}
@Override
public void remove() {
if (node == null) {
throw new IndexOutOfBoundsException();
}
if (node.prev != null) {
node.prev.next = node.next;
}
if (node.next != null) {
node.next.prev = node.prev;
}
nodeMap.remove(node.documentID);
}
};
}
}