设计模式(16)--迭代器模式

来源:互联网 发布:红警3 for mac版 编辑:程序博客网 时间:2024/05/21 11:09

迭代器模式很好理解,简单说就是,我们有个集合,如果不使用迭代器模式,集合就承担了存储数据和遍历数据的多个任务,不符合单一职责原则。而通过使用迭代器,将集合的迭代抽象出来,专门负责集合的迭代。

迭代器模式UML类图:


其中MyList(自定义集合类)和Iter(迭代器接口实现类)是内部类关联关系

示例代码:

迭代器接口:

public interface Iterator { boolean hasNext(); Object next(); void remove();}

集合类(其中迭代器的实现类是以集合类内部类出现的,为了方便处理集合数据):

/**** * 自定义集合类 * @author wjw * */public class MyList {private List list = new ArrayList();public Iterator iterator(){return new Iter();}/**** * 内部类实现迭代器 * @author wjw * */private class Iter implements Iterator{ public boolean hasNext(){ System.out.println("判断游婊下一处是否有数据!"); return true; } public Object next(){ return "本游标处集合中数据"; } public void remove(){ System.out.println("移除集合中本游标处数据!"); };}}

Main类:

public class Main {public static void main(String[] args) throws InterruptedException {MyList mylist = new MyList();Iterator iterator = mylist.iterator();int i = 0;while(iterator.hasNext()){Thread.sleep(1000);i++;String temp = (String)iterator.next();System.out.println(temp);if(i == 10){iterator.remove();}}}}


运行结果:

判断游婊下一处是否有数据!
本游标处集合中数据
判断游婊下一处是否有数据!
本游标处集合中数据
判断游婊下一处是否有数据!
本游标处集合中数据
判断游婊下一处是否有数据!
本游标处集合中数据
判断游婊下一处是否有数据!
本游标处集合中数据
判断游婊下一处是否有数据!
本游标处集合中数据
判断游婊下一处是否有数据!
本游标处集合中数据
判断游婊下一处是否有数据!
本游标处集合中数据
判断游婊下一处是否有数据!
本游标处集合中数据
判断游婊下一处是否有数据!
本游标处集合中数据
移除集合中本游标处数据!
判断游婊下一处是否有数据!
本游标处集合中数据


大家感觉实例代码中Main类中的代码熟悉吗?是的,其实我们JAVA的集合遍历就是这样实现的,示例代码中的Iterator我是照抄JDK源码,这个实例其实就是JAVA集合遍历的简单版。我们主要理解这种设计模式,将集合的存储数据的功能和遍历集合的功能解耦。

正式定义一下迭代器模式就是:

提供一种方法顺序访问集合中各个元素,而不暴露该对象的内部表示。


有时间的话再详细分析一下这一部分源码,我想能加深对迭代器模式理解。


如有错误,欢迎指正。

end

原创粉丝点击