迭代器模式Iterator Pattern-23种常用设计模式快速入门教程
1.迭代器模式定义
迭代器模式是一种行为型设计模式,它可以让我们在不暴露集合内部结构的情况下,对集合的元素进行遍历操作。
2.迭代器模式优点
它支持以不同的方式遍历一个集合,它支持对集合的多种遍历,它可以为遍历不同的集合提供统一的接口。
3.迭代器模式缺点
它的迭代行为是依赖于集合的内部结构而变化的,它增加了集合的复杂性,使得集合的设计变得更加复杂。
4.迭代器模式示例代码
传统设计模式讲解时使用的示例代码,大都采用与读者日常生活接解的业务系统没有多大关联关系。以致大部分读者无法做到学以致用,学完就忘记。本文采用使用日常生活中随处可见的优惠券业务来编写实现代码:
//定义迭代器模式的抽象迭代器类
public abstract class CouponIterator {
public abstract boolean hasNext(); public abstract String next();
}
//定义迭代器模式的具体迭代器类
public class ConcreteCouponIterator extends CouponIterator {
private List<String> couponList;
private int index;
public ConcreteCouponIterator(List<String> couponList) {
this.couponList = couponList; index = 0;
}
@Override
public boolean hasNext() {
return index < couponList.size(); }
@Override
public String next() {
return couponList.get(index++);
}
}
//迭代器模式的客户端使用
public class Client {
public static void main(String[] args) {
List<String> couponList = Arrays.asList("discount", "free shipping");
CouponIterator couponIterator = new ConcreteCouponIterator(couponList);
while (couponIterator.hasNext()) {
System.out.println(couponIterator.next());
}
}
}