首页 > 其他 > 详细

迭代器模式

时间:2020-11-27 17:22:16      阅读:26      评论:0      收藏:0      [点我收藏+]
此文转载自:https://my.oschina.net/u/3057088/blog/4754814

迭代器模式:提供一种方法顺序访问一个聚合对象中的各种元素,而又不暴露该对象的内部表示。

迭代器模式适用场景:

  • 访问一个聚合对象的内容而无需暴露它的内部表示
  • 支持对聚合对象的多种遍历
  • 为遍历不同的聚合结构提供一个统一的接口

迭代器模式组件:

  • Aggregate(聚合-抽象容器角色):定义集合并负责创建具体迭代器对象的接口
  • ConcreteAggregate(具体聚合-具体容器角色):实现抽象容器的具体实现类
  • Iterator(抽象迭代器角色):负责定义访问和遍历元素的接口
  • ConcreteIterator(具体迭代器角色):实现迭代器接口

迭代器模式组件实例:
抽象容器角色:

public class User {
    private String name;
    private Integer age;

    public User(String name, Integer age) {
        this.name = name;
        this.age = age;
    }

    @Override
    public String toString() {
        return "User{" +
                "name=‘" + name + ‘\‘‘ +
                ", age=" + age +
                ‘}‘;
    }
}
public interface Aggregate {
    Iterator<User> iterator();
}

具体容器角色:

import java.util.ArrayList;
import java.util.List;

public class ConcreteAggregate implements Aggregate {
    private List<User> list = new ArrayList<>();

    public ConcreteAggregate() {
        list.add(new User("luther0", 30));
        list.add(new User("luther1", 31));
        list.add(new User("luther2", 32));
        list.add(new User("luther3", 33));
    }

    @Override
    public Iterator<User> iterator() {
        return new ConcreteIterator(list);
    }
}

抽象迭代器角色:

public interface Iterator<T> {
    boolean hasNext();
    T next();
}

具体迭代器角色:

import java.util.Arrays;
import java.util.List;

public class ConcreteIterator implements Iterator<User> {
    private List<User> userList;
    private int index;

    public ConcreteIterator(List<User> userList) {
        this.userList = userList;
    }

    public ConcreteIterator(User[] users) {
        this.userList = Arrays.asList(users);
    }

    @Override
    public boolean hasNext() {
        return index < userList.size();
    }

    @Override
    public User next() {
        return userList.get(index++);
    }
}

客户端调用:

public class App {
    public static void main(String[] args) {
        Iterator<User> iterator = new ConcreteAggregate().iterator();
        while (iterator.hasNext()) {
            User next = iterator.next();
            System.out.println(next.toString());
        }
    }
}

迭代器模式总结:

  • 封装容器的内部实现细节,简化客户端的访问和获取容器内数据。
  • 客户端可以通过相同的方式遍历不同的容器对象。
  • 我们可以根据客户端需求让容器实现不同的迭代算法,从而可以用不同的遍历方式来访问容器数据。
  • 增加了系统复杂度,但是便于扩展

迭代器模式

原文:https://www.cnblogs.com/phyger/p/14048512.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!