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;
}
@Override
public boolean hasNext() {
return currentPosition < animals.size() - 1;
}
@Override
public 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】。