admin管理员组

文章数量:1441534

迭代器模式Iterator Pattern

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());

}

}

}

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。 原始发表:2023-03-03,如有侵权请联系 cloudcommunity@tencent 删除iteratorpublic遍历集合设计模式

本文标签: 迭代器模式Iterator Pattern