一、迭代器模式的定义
迭代器模式( Iterator Pattern ) 又称为游标模式(Cursor Pattern), 它提供一种顺序访问集合/
容器对象元素的方法,而又无须暴露集合内部表示。迭代器模式可以为不同的容器提供一致的
遍历行为,而不用关心容器内容元素组成结构,属于行为型模式。
原文 : Provide a way to access the elements of an aggregate object sequentially without exposing its under lying representation.
解释:提供一种顺序访问集合/容器对象元素的方法,而又无须暴露集合内部表示。
迭代器模式的本质是抽离集合对象迭代行为到迭代器中,提供一致访问接口。
二、迭代器的应用场景
迭代器模式在我们生活中应用的得也比较广泛,比如物流系统中的传送带,不管传送的是什
么物品,都被打包成一个一个的箱子并且有一个统一的二维码。这样我们不需要关心箱子里面
是啥,我们在分发时只需要一个一个检查发送的目的地即可。再比如,我们平时乘坐交通工具,
都是统一刷卡或者刷脸进站,而不需要关心是男性还是女性、是残疾人还是正常人等个性化的信息。
我们把多个对象聚在一起形成的总体称之为集合(Aggregate), 集合对象是能够包容一组对 象的容器对象。不同的集合其内部元素的聚合结构可能不同,而迭代器模式屏蔽了内部元素获
取细节,为外部提供一致的元素访问行为,解耦了元素迭代与集合对象间的耦合,并且通过提
供不同的迭代器,可以为同个集合对象提供不同顺序的元素访问行为,扩展了集合对象元素迭
代功能,符合开闭原则。迭代器模式适用于以下场景:
1、 访问一个集合对象的内容而无需暴露它的内部表示;
2、 为遍历不同的集合结构提供一个统一的访问接口。
从 UML类图中,我们可以看到,迭代器模式主要包含三种角色:
抽象迭代器( Iterator) : 抽象迭代器负责定义访问和遍历元素的接口 ;
具体迭代器( Concreteiterator) :提供具体的元素遍历行为;
抽象容器(Aggregate ) : 负责定义提供具体迭代器的接口 ;
具体容器(ConcreteAggregate ) :创建具体迭代器。
.手写自定义的送代器
总体来说,迭代器模式还是非常简单的。我们还是以课程为例,下面我们自己创建一个课程的集合,集合中的每一个元素就是课程对象,然后自己手写一个迭代器,将每一个课程对象的信息读出来。
首先创建集合元素课程Course类 :
public class Course { private String name; public Course(String name) { this.name = name; } public String getName() { return name; } }
然后创建自定义迭代器Iterator接口 :
public interface Iterator<E> { E next(); boolean hasNext(); }
然后创建自定义的课程的集合ICourseAggregate接口 :
public interface ICourseAggregate { void add(Course course); void remove(Course course); Iterator<Course> iterator(); }
然后,分别实现迭代器接口和集合接口,创建Iteratorlmpl实现类:
public class IteratorImpl<E> implements Iterator<E> { private List<E> list; private int cursor; private E element; public IteratorImpl(List<E> list) { this.list = list; } public E next() { System.out.print("当前位置 " + cursor + " : "); element = list.get(cursor); cursor ++; return element; } public boolean hasNext() { if(cursor > list.size() - 1){ return false; } return true; } }
创建课程集合CourseAggregatelmpI 实现类:
public class CourseAggregateImpl implements ICourseAggregate { private List courseList; public CourseAggregateImpl() { this.courseList = new ArrayList(); } public void add(Course course) { courseList.add(course); } public void remove(Course course) { courseList.remove(course); } public Iterator<Course> iterator() { return new IteratorImpl<Course>(courseList); } }