码农小汪-设计模式-迭代器模式
2016-04-16 21:05
525 查看
迭代器模式 iterator
迭代器模式:提供了一种方法顺序的访问一个聚合对象中的各个元素,而又不暴露该对象的内部表示这个我们在Java中使用的还是比较的广泛的,这一点我们需要清除这个问题。这个东西,挺简单的,看看就晓得了
优点: 1、它支持以不同的方式遍历一个聚合对象。 2、迭代器简化了聚合类。 3、在同一个聚合上可以有多个遍历。 4、在迭代器模式中,增加新的聚合类和迭代器类都很方便,无须修改原有代码。
缺点:由于迭代器模式将存储数据和遍历数据的职责分离,增加新的聚合类需要对应增加新的迭代器类,类的个数成对增加,这在一定程度上增加了系统的复杂性。
注意事项:迭代器模式就是分离了集合对象的遍历行为,抽象出一个迭代器类来负责,这样既可以做到不暴露集合的内部结构,又可让外部代码透明地访问集合内部的数据。
我们将创建一个叙述导航方法的 Iterator 接口和一个返回迭代器的 Container 接口。实现了 Container 接口的实体类将负责实现 Iterator 接口。
![](http://c.hiphotos.baidu.com/image/pic/item/7acb0a46f21fbe09c9b56a866c600c338644adbd.jpg)
这个是我们迭代器需要实现的接口
public interface Iterator { public boolean hasNext(); public Object next(); }
容器需要实现的接口 获得自己的迭代器对象
public interface Container { public Iterator getIterator(); }
创建实现了 Container 接口的实体类。该类有实现了 Iterator 接口的内部类 NameIterator。
public class NameRepository implements Container { public String names[] = {"Robert" , "John" ,"Julie" , "Lora"}; @Override public Iterator getIterator() { return new NameIterator(); } private class NameIterator implements Iterator { int index; @Override public boolean hasNext() { if(index < names.length){ return true; } return false; } @Override public Object next() { if(this.hasNext()){ return names[index++]; } return null; } } }
使用这个哦,就是这么简单~~
public class IteratorPatternDemo { public static void main(String[] args) { NameRepository namesRepository = new NameRepository(); for(Iterator iter = namesRepository.getIterator(); iter.hasNext();){ String name = (String)iter.next(); System.out.println("Name : " + name); } } } Name : Robert Name : John Name : Julie Name : Lora
我们Java中的集合框架也是类似的使用了迭代器哦~
//迭代器 ,该接口提供了迭代遍历的通用方法 public interface Iterator { boolean hasNext(); Object next(); void remove(); } //容器迭代化接口,凡是实现此接口的集合容器距可以生成相应的迭代器 public interface Iterable<T>{ //产生迭代器,将容器对象转换为迭代器对象 Iterator<T> interator(); } //java集合框架的根接口,该接口继承了容器迭代化接口,因此java中的集合都可以被迭代 public interface Collection<E> extends Iterable<E>
相关文章推荐
- lintcode之最长公共前缀
- 【笔试/面试】MFC(六)—— 菜单
- 一个大四求职菜鸟的web前端之路(终)
- 码农小汪-设计模式-模板方法
- 写了 35 年代码的老程序员的最大遗憾
- 码农小汪-设计模式-享元模式 FlyWeight
- 程序员的自我提升
- lintcode 之 最长公共子串
- 【笔试/面试】MFC(五)
- 码农小汪-设计模式之-命令模式
- 模拟面试感受之一
- 面试题87:玛瑙项链
- 剑指offer 面试题15: 链表中倒数第k个结点 题解
- 剑指 4000 offer-面试题45:圆圈中最后的数字
- 某公司面试block
- JAVA多线程和并发基础面试问答
- 腾讯2面
- leetcode之largest number
- 面试题目——String
- 人生第一面总结