• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
思想人生从关注生活开始
博客园    首页    新随笔    联系   管理    订阅  订阅

迭代器模式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());
}
}
}
 
 
posted @ 2023-03-03 10:30  JackYang  阅读(34)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3