首页 > 其他 > 详细

迭代器模式

时间:2017-10-25 00:25:05      阅读:262      评论:0      收藏:0      [点我收藏+]

提供一种方法访问一个容器对象中各个元素,而又不暴露该对象的内部细节。

 技术分享

迭代器模式的结构

  • 抽象容器:一般是一个接口,提供一个iterator()方法,例如java中的Collection接口,List接口,Set接口等。
  • 具体容器:就是抽象容器的具体实现类,比如List接口的有序列表实现ArrayList,List接口的链表实现LinkList,Set接口的哈希列表的实现HashSet等。
  • 抽象迭代器:定义遍历元素所需要的方法,一般来说会有这么三个方法:取得第一个元素的方法first(),取得下一个元素的方法next(),判断是否遍历结束的方法isDone()(或者叫hasNext()),移出当前对象的方法remove(),
  • 迭代器实现:实现迭代器接口中定义的方法,完成集合的迭代。

Container

package design.pattern.iterator;

public interface Container {
    public Iterator getIterator();
}

Iterator

package design.pattern.iterator;

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

ConcreteContainer

package design.pattern.iterator;

public class ConcreteContainer implements Container {

    private int[] arr = {0, 1, 2, 3, 4, 5};
    
    @Override
    public Iterator getIterator() {
        return new ConcreteIterator();
    }
    
    private class ConcreteIterator implements Iterator {
        
        private int index=0;
        
        @Override
        public boolean hasNext() {
            return index < arr.length;
        }

        @Override
        public Object next() {
            if (!this.hasNext())
                return null;
            return arr[index++];
        }

    }

}

Client

package design.pattern.iterator;

public class Client {
    public static void main(String[] args) {
        Iterator it = new ConcreteContainer().getIterator();
        
        while (it.hasNext()) {
            System.out.println(it.next());
        }
    }
}

 

迭代器模式

原文:http://www.cnblogs.com/m2492565210/p/7461553.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!