nestediterator.java

来自「Rapla是一个灵活的多用户资源管理系统。它提供的一些功能有:日历GUI」· Java 代码 · 共 74 行

JAVA
74
字号
/*--------------------------------------------------------------------------*
 | Copyright (C) 2006 Christopher Kohlhaas                                  |
 |                                                                          |
 | This program is free software; you can redistribute it and/or modify     |
 | it under the terms of the GNU General Public License as published by the |
 | Free Software Foundation. A copy of the license has been included with   |
 | these distribution in the COPYING file, if not go to www.fsf.org         |
 |                                                                          |
 | As a special exception, you are granted the permissions to link this     |
 | program with every library, which license fulfills the Open Source       |
 | Definition as published by the Open Source Initiative (OSI).             |
 *--------------------------------------------------------------------------*/
package org.rapla.components.util.iterator;

import java.util.NoSuchElementException;
import java.util.Iterator;

/**Successivly iterates over the elements specified in the nested Iterators.
Example of an recursive traversal of an Entity Tree:
<pre>
class RecursiveEntityIterator extends NestedIterator {
    public RecursiveEntityIterator(Iterator it) {
        super(it);
    }
    public Iterator getNestedIterator(Object obj) {
        return new RecursiveEntityIterator(((Entity)obj).getSubEntities());
    }
}
</pre>
*/

public abstract class NestedIterator implements Iterator {
    protected Iterator outerIt;
    protected Iterator innerIt;
    Object nextElement;
    boolean isInitialized;
    public NestedIterator(Iterator outerIt) {
        this.outerIt = outerIt;
    }

    private Object nextElement() {
        while (outerIt.hasNext() || (innerIt != null && innerIt.hasNext())) {
            if (innerIt != null && innerIt.hasNext())
                return innerIt.next();
            innerIt = getNestedIterator(outerIt.next());
        }
        return null;
    }

    public abstract Iterator getNestedIterator(Object obj);

    public boolean hasNext() {
        if (!isInitialized)
        {
            nextElement = nextElement();
            isInitialized = true;
        }
        return nextElement != null;
    }

    public void remove() {
        throw new UnsupportedOperationException();
    }

    public Object next() {
        if (!hasNext())
            throw new NoSuchElementException();
        Object result = nextElement;
        nextElement = nextElement();
        return result;
    }
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?