迭代器模式是java和.NET环境中一种非常常用的设计模式,属于行为型模式。这种模式用来顺序访问集合对象的元素,而不用关心其底层表示。
介绍
意图:提供一个方法可以顺序访问聚合对象的元素,而不用暴露该对象的内部表示。
解决:不同的方式遍历整个集合对象
何时使用:遍历一个聚合对象
如何解决:把元素之间游走的职责交给迭代器,而不是聚合对象
关键代码:hasNext()、Next()接口
应用实例:Java中的iterator
优点:1.它 支持不同的方式去遍历一个聚合对象 2. 迭代器简化了聚合类 3.在同一个聚合上可以有多个遍历 4. 在迭代器模式中,新增聚合类和迭代器类很方便,无需改变原有的代码
缺点:由于迭代器模式将存储数据和遍历数据的职责分离,增加新的聚合类需要对应增加新的迭代器类,类的个数成对增加,这在一定程度上增加了系统的复杂性。
使用场景:1.访问一个聚合对象的内容而无需暴露它的内部表示 2. 需要为聚合对象提供不同的遍历方式 3. 为遍历不同的聚合结构提供一个统一的接口
注意事项:迭代器模式就是分离了集合对象的遍历行为,抽象出一个迭代器类来负责,这样既可以做到不暴露集合的内部结构,又可让外部代码透明地访问集合内部的数据。
实现
创建一个提供方法的 Iterator 接口和一个返回迭代器的 Container 接口。实现了 Container 接口的实体类将负责实现 Iterator 接口。
IteratorPatternDemo,我们的演示类使用实体类 NamesRepository 来打印 NamesRepository 中存储为集合的 Names。
第一步:实现提供方法的Iterator接口和返回迭代器的Container接口
public interface Iterator {
public boolean hasNext();
public Object next();
}
public interface Container {
public Iterator getInterator();
}
第二步:实现Container接口的实体类,该类内部有实现了Iterator接口的内部类
public class NameRepository implements Container{
private String names[]={"Alice","Peter","Jack","Rose","Dick"};
@Override
public Iterator getInterator() {
return new NameIerator();
}
private class NameIerator implements Iterator
{
int index;
@Override
public boolean hasNext() {
if(index<names.length)
{
return true;
}else{
return false;
}
}
@Override
public Object next() {
if(this.hasNext())
{
return names[index++];
}
return null;
}
}
}
第三步:使用迭代器打印names数组中的名字
public class IteratorPatternDemo {
public static void main(String []args)
{
NameRepository nameRepository=new NameRepository();
for(Iterator iterator=nameRepository.getInterator();iterator.hasNext();)
{
System.out.println("名字:"+iterator.next());
}
}
}
第四步:验证输出结果:
名字:Alice
名字:Peter
名字:Jack
名字:Rose
名字:Dick
经过简单学习之后,对迭代器模式有了一定的了解和认知。