设计模式—迭代器模式
迭代器模式
这种模式用于顺序访问集合对象的元素,不需要知道集合对象的底层表示。
迭代器模式属于行为型模式。
思考问题:如何实现顺序访问且不知道集合底层表示?
例子:
- 迭代接口
package org.kouhao.design.patterns.迭代模式;
/**
 * @author admin
 */
public interface Iterator<E> {
    /**
     * 是否具有下一个数据
     *
     * @return 是否
     */
    boolean hasNext();
    /**
     * 获取下一个数据
     *
     * @return 数据
     */
    E next();
}
- 容器接口
package org.kouhao.design.patterns.迭代模式;
/**
 * @author admin
 */
public interface IContainer<E> {
    Iterator<E> iterator();
}
- 具体容器实现类
package org.kouhao.design.patterns.迭代模式;
/**
 * @author admin
 */
public class NameRepository implements IContainer<String> {
    public String[] names = {"Robert", "John", "Julie", "Lora"};
    @Override
    public Iterator<String> iterator() {
        return new NameIterator();
    }
    private class NameIterator implements Iterator<String> {
        int index;
        @Override
        public boolean hasNext() {
            return index < names.length;
        }
        @Override
        public String next() {
            if (this.hasNext()) {
                return names[index++];
            }
            return null;
        }
    }
}
- 客户端
package org.kouhao.design.patterns.迭代模式;
public class Client {
    public static void main(String[] args) {
        NameRepository namesRepository = new NameRepository();
        for (Iterator<String> iter = namesRepository.iterator(); iter.hasNext(); ) {
            String name = iter.next();
            System.out.println("Name : " + name);
        }
    }
}
- 输出
Name : Robert
Name : John
Name : Julie
Name : Lora
 
                    
                
 
                
            
         浙公网安备 33010602011771号
浙公网安备 33010602011771号