设计模式—迭代器模式

迭代器模式

这种模式用于顺序访问集合对象的元素,不需要知道集合对象的底层表示。

迭代器模式属于行为型模式

思考问题:如何实现顺序访问且不知道集合底层表示?

例子:

  • 迭代接口
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

posted @   弘一  阅读(3)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
点击右上角即可分享
微信分享提示