设计模式 - 迭代器模式

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

 

迭代器模式中的角色

抽象迭代器:抽象迭代器负责定义访问和遍历元素的接口。迭代器的抽象是为了使迭代器不依赖于容器的内部结构。

具体迭代器:具体迭代器要实现迭代器接口,并要记录遍历中的当前位置。

抽象容器:抽象容器负责提供创建迭代器的接口。

具体容器:具体容器要实现创建具体迭代器的接口,这个具体迭代器与该具体容器的内部结构相关。

 

类图

 

代码实现

抽象迭代器:

package com.huey.pattern.iterator;

/**
 * the iterator interface
 * @author  huey
 * @version 1.0 
 * @created 2015-11-26
 * @param <E>
 */
public interface Iterator<E> {

    public boolean hasNext();
    
    public E next();
    
}

具体迭代器:

package com.huey.pattern.iterator;

import java.util.Arrays;

/**
 * the concrete iterator
 * @author  huey
 * @version 1.0 
 * @created 2015-11-26
 * @param <E>
 */
public class SortedIterator<E> implements Iterator<E> {
    
    private E[] items;
    int index = 0;
    
    public SortedIterator(E[] items) {
        this.items = items;
        if (items != null && items.length > 0 && items[0] != null 
                && items[0] instanceof Comparable<?>) {
            Arrays.sort(this.items);
        }
    }
    
    @Override
    public boolean hasNext() {
        if (items == null || index >= items.length || items[index] == null) {
            return false;
        }
        return true;
    }
    
    @Override
    public E next() {
        E item = items[index++];
        return (E) item;
    }
    
}

抽象容器:

package com.huey.pattern.iterator;

/**
 * the container interface
 * @author  huey
 * @version 1.0 
 * @created 2015-11-26
 * @param <E>
 */
public interface Collection<E> {
    
    public boolean add(E e);
    
    /**
     * get the iterator
     * @return
     */
    public Iterator<E> iterator();
    
}

具体容器:

package com.huey.pattern.iterator;

import java.lang.reflect.Array;
import java.util.Arrays;

/**
 * the concrete container
 * @author  huey
 * @version 1.0 
 * @created 2015-11-26
 * @param <E>
 */
public class SortedList<E> implements Collection<E> {
    
    private E[] items;
    private int size;
    
    @SuppressWarnings("unchecked")
    public SortedList(Class<E> type) {
        items = (E[]) Array.newInstance(type, 10);
        size = 0;
    }
    
    public boolean add(E e) {
        ensureCapacity(size + 1);
        items[size++] = e;
        return true;
    }
    
    @Override
    public Iterator<E> iterator() {
        return new SortedIterator<E>(items);
    }
    
    public void ensureCapacity(int minCapacity) {
        int oldCapacity = items.length;
        if (minCapacity > oldCapacity) {
            int newCapacity = (oldCapacity * 3) / 2 + 1;
            if (newCapacity < minCapacity)
                newCapacity = minCapacity;
            // minCapacity is usually close to size, so this is a win:
            items = Arrays.copyOf(items, newCapacity);
        }
    }
}

单元测试:

package com.huey.pattern.iterator;

public class IteratorPatternTest {

    public static void main(String[] args) {        
        Collection<Long> container = new SortedList<Long>(Long.class);
        container.add(2L);
        container.add(0L);
        container.add(1L);
        container.add(5L);
        
        Iterator<Long> iterator = container.iterator();
        while (iterator.hasNext()) {
            Long item = iterator.next();
            System.out.println(item);
        }
    }
}

结果输出:

0
1
2
5

 

迭代器模式的适用场合

1) 访问一个集合对象的内容,而无须暴露它的内部表示。

2) 支持对集合对象的多种遍历方式。

3) 为遍历不同的集合对象结构提供一个统一的接口。

 

Java SDK 中的迭代器模式

迭代器对于集合容器类的遍历非常有效和实用,在 JDK 中,已经定义了 java.util.Iterator、java.lang.Iterable、java.util.Collection 等接口。

 

posted on 2015-11-26 20:55  huey2672  阅读(228)  评论(0编辑  收藏  举报