【设计模式 - 16】之迭代器模式(Iterator)

来源:互联网 发布:时时彩源码免费下载 编辑:程序博客网 时间:2024/05/01 04:36

1      模式简介

迭代器模式是JAVA中非常常用的模式,List、Map、Set等常见集合中都封装了迭代器Iterator。

 

迭代器模式的介绍:

迭代器模式用于顺序访问集合对象中的元素,而不需要知道集合对象的底层表示,即可以将在元素之间游走的责任交给迭代器,而不是集合对象本身。

 

迭代器模式的优点:

1)        它支持以不同的方式遍历一个聚合对象;

2)        迭代器简化了集合类;

3)        在同一个集合上可以有多个遍历(如顺序遍历、倒序遍历等);

4)        在迭代器模式中,增加新的集合类和迭代器类都很方便,无须修改原有代码。

 

迭代器模式的缺点:

由于迭代器模式将存储数据和遍历数据的职责分离,增加新的聚合类需要对应增加新的迭代器类,类的个数成对增加,这在一定程度上增加了系统的复杂性。

 

迭代器模式的适用场景:

1)        当想要访问一个集合对象的内容而不想暴露它的内部表示时;

2)        当需要为集合对象提供多种遍历方式时;

3)        当想为遍历不同的集合结构提供一个统一的接口时。

 

2      案例

在这个案例中,我们在AnimalCollection中封装一个List,在List中存储Animal的信息,通过AnimalIterator遍历AnimalCollection中的List中的信息并输出。


具体代码如下:

迭代器接口Iterator中的代码:

public interface Iterator {// 是否还有下一个元素boolean hasNext();// 获取下一个元素Object next();}
Animal集合类AnimalCollection中的代码:

public class AnimalCollection {private List<String> animals;public AnimalCollection() {this.animals = new ArrayList<>();}public void addAnimal(String animal) {animals.add(animal);}public Iterator iterator() {return new AnimalIterator(animals);}}
Animal集合的迭代器AnimalIterator中的代码:

public class AnimalIterator implements Iterator {private List<String> animals;private int currentPosition;public AnimalIterator(List<String> animals) {this.animals = animals;this.currentPosition = -1;}@Overridepublic boolean hasNext() {return currentPosition < animals.size() - 1;}@Overridepublic Object next() {return animals.get(++currentPosition);}}
测试类Test中的代码:

public class Test {public static void main(String[] args) {AnimalCollection animalCollection = new AnimalCollection();animalCollection.addAnimal("小猫");animalCollection.addAnimal("小狗");animalCollection.addAnimal("小驴");animalCollection.addAnimal("兔兔");Iterator iterator = animalCollection.iterator();while (iterator.hasNext()) {System.out.println(iterator.next());}}}
运行结果如下图所示:



最后贴出迭代器模式在GitHub中的代码地址:【GitHub - Iterator】。

1 0
原创粉丝点击