设计模式:迭代器模式
2019-01-16 05:51:29来源:博客园 阅读 ()
迭代器模式又称游标模式,该模式可以顺序访问一个集合中元素而不必暴露集合内部对象。
在Java集合框架Collection中广泛使用该模式来遍历内部元素。所有熟悉java语言的应该都了解并应用过。
采用迭代器遍历对象。
迭代器结构:
聚合对象(collection):存储数据
迭代器:遍历数据
例子:
简单自己实现一个列表元素的迭代器。
public interface MyIterator { //指向第一个元素 void first(); //指向下一个元素 Object next(); //是否存在下一个元素 boolean hasNext(); boolean isFirst(); boolean isLast(); }
/** * 自定义集合对象 */ public class MyCollection { private List<Object> list = new ArrayList<>(); public void add(Object obj) { list.add(obj); } public void remove(Object obj) { list.remove(obj); } public List<Object> getList() { return list; } public void setList(List<Object> list) { this.list = list; } public MyIterator iterator() { return new SelfIterator(); } class SelfIterator implements MyIterator { //定义一个索引位置表示游标 private int index; //指向第一个元素即索引为0 @Override public void first() { index = 0; } @Override public Object next() { if (index < list.size()) { Object obj = list.get(index); index++; return obj; } return null; } @Override public boolean hasNext() { return index < list.size(); } @Override public boolean isFirst() { return index == 0; } @Override public boolean isLast() { return index == (list.size() - 1); } } }
简化起见,在这个集合对象封装一个数组,初始化时就创建好该数组
public class Client { public static void main(String[] args) { MyCollection collection = new MyCollection(); collection.add("1"); collection.add("2"); collection.add("3"); MyIterator iterator = collection.iterator(); while (iterator.hasNext()){ System.out.println(iterator.next()); } } }
迭代器模式使遍历算法和集合对象分开,单独被封装在迭代子对象中,外部只需要调用迭代子对象的方法。
迭代和集合对象解耦。新增迭代方式的时候可以不用修改集合对象,只需新增迭代器对象即可,符合开闭原则。
原文链接:https://www.cnblogs.com/gcm688/p/10274249.html
如有疑问请与原作者联系
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:Eclipse常用20个快捷键
下一篇:java版游戏辅助,自动化程序。
- 设计模式-委派/策略模式 2020-06-09
- 深入理解:设计模式中的七大设计原则 2020-06-07
- 设计模式---类之间的关系知多少 2020-06-07
- 你与面试官所了解的单例模式并不一样! 2020-06-06
- 高手眼中的观察者模式有什么不一样 2020-06-05
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash