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
版权声明:本文标题:迭代器模式Iterator Pattern 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/biancheng/1747898997a2773296.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论