<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    夢幻之旅

    DEBUG - 天道酬勤

       :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
      671 隨筆 :: 6 文章 :: 256 評論 :: 0 Trackbacks
    迭代器模式,又叫游標模式.

    提供一種方法訪問一個容器(container)對象中各個元素,而又不需暴露該對象的內部細節。
    在迭代器模式中,具體迭代器角色和具體容器角色是耦合在一起的 —— 遍歷算法是與容器的內部細節緊密相關的。為了使客戶程序從與具體迭代器角色耦合的困境中脫離出來,避免具體迭代器角色的更換給客戶程序帶來的修改,迭代器模式抽象了具體迭代器角色,使得客戶程序更具一般性和重用性。這被稱為多態迭代
    迭代器模式的組成部份
    1.集合,一個接口,規定了具體集合需要實現的操作.
    2.具體集合,是實現集合接口的實例,具體集合按著一定的結構存儲對象,具體集合應當有一個方法返回針對該集合的具體迭代器.
    3.迭代器, 一個接口,規定了遍歷集合的方法.
    4.具體迭代器
    迭代器各組成部份之間的關系

    例子:
    集合:

    package iterator;

    public interface Aggregate<E>
    {
        
    public Iterator<E> createIterator();
        
        
    public int length();
        
        
    public E get(int index);
        
        
    public void add(E obj);
    }

    具體集合:

    package iterator;

    import java.util.ArrayList;
    import java.util.List;

    public class ConcreteAggregate<E> implements Aggregate<E>
    {
        
    private List<E> items = new ArrayList<E>();
        
        
    public Iterator<E> createIterator()
        
    {
            
    return new ConcreteIterator<E>(this);
        }

        
        
    public int length()
        
    {
            
    return items.size();
        }

        
        
    public E get(int index)
        
    {
            
    return (E) items.get(index);
        }

        
        
    public void add(E obj)
        
    {
            items.add(obj);
        }

        
    }



    迭代器:

     

    package iterator;

    public interface Iterator<E>
    {
        
    public E first();
        
        
    public boolean hasNext();
        
        
    public E next();
        
        
    public E current();
    }


    具體迭代器:

    package iterator;

    public class ConcreteIterator<E> implements Iterator<E>
    {
        
    private Aggregate<E> aggregate;
        
        
    private int currentIndex = 0;
        
        
    public ConcreteIterator(Aggregate<E> aggregate)
        
    {
            
    this.aggregate = aggregate;
        }

        
        
    public E first()
        
    {
            currentIndex 
    = 0;
            
    if (hasNext())
            
    {
                
    return aggregate.get(currentIndex);
            }

            
    else
            
    {
                
    return null;
            }

        }

        
        
    public boolean hasNext()
        
    {
            
    return (currentIndex < aggregate.length());
        }

        
        
    public E next()
        
    {
            currentIndex
    ++;
            
    if (hasNext())
            
    {
                
    return aggregate.get(currentIndex);
            }

            
    else
            
    {
                
    return null;
            }

        }

        
        
    public E current()
        
    {
            
    return aggregate.get(currentIndex);
        }

    }



    測試類:

    package iterator;

    public class Test
    {
        
    public static void main(String[] args)
        
    {
            Aggregate
    <String> a = new ConcreteAggregate<String>();
            a.add(
    "111");
            a.add(
    "222");
            a.add(
    "333");
            
            Iterator
    <String> it = a.createIterator();
            
    for (String s = it.first(); it.hasNext(); s = it.next())
            
    {
                System.out.println(s);
            }

        }

        
    }

    迭代器的優點:
          1、支持以不同的方式遍歷一個容器角色。根據實現方式的不同,效果上會有差別。
          2、簡化了容器的接口。但是在java Collection中為了提高可擴展性,容器還是提供了遍歷的接口。
          3、對同一個容器對象,可以同時進行多個遍歷。因為遍歷狀態是保存在每一個迭代器對象中的。

    posted on 2011-08-01 13:29 HUIKK 閱讀(296) 評論(0)  編輯  收藏 所屬分類: Design Patterns
    主站蜘蛛池模板: 亚洲国产日韩一区高清在线 | 久久精品国产亚洲AV蜜臀色欲 | 国产日韩AV免费无码一区二区| 久久久无码精品亚洲日韩按摩| 亚洲精品中文字幕无乱码| 男女作爱在线播放免费网站| 最近免费中文字幕大全视频| 亚洲欧洲国产精品久久| 一个人免费观看视频在线中文| 十八禁无码免费网站| 亚洲A丁香五香天堂网| 亚洲一区精品视频在线| 一二三四影视在线看片免费| 亚洲人AV在线无码影院观看| 国产美女a做受大片免费| 亚洲国产韩国一区二区| 毛片a级毛片免费播放100| 一区二区三区在线免费观看视频| a级黄色毛片免费播放视频| 亚洲成av人片在线观看无码不卡| 久久精品免费观看国产| 亚洲精品国产精品国自产网站| 青青草国产免费久久久下载| 一级毛片a免费播放王色电影 | 精品无码AV无码免费专区| 亚洲伊人久久成综合人影院| 亚洲日韩精品无码专区加勒比 | avtt亚洲天堂| 国产午夜精品久久久久免费视 | 2021精品国产品免费观看 | 好爽…又高潮了毛片免费看| 国产亚洲成av片在线观看| 国产偷国产偷亚洲高清在线 | 亚洲精品日韩中文字幕久久久| 免费av欧美国产在钱| 亚洲色偷偷av男人的天堂| 免费高清资源黄网站在线观看 | 久久亚洲精品国产亚洲老地址 | 亚洲人成网亚洲欧洲无码| 国产亚洲精品无码专区| www免费插插视频|