迭代器模式(在對象的集合中游走,但是不暴露集合的實現(xiàn))

源碼地址 https://github.com/DingMouRen/DesignPattern
迭代器模式.png
  • Iterator迭代器接口負責定義、訪問和遍歷元素的接口
  • ConcreteIterator具體迭代器類主要實現(xiàn)迭代器接口,并記錄遍歷的當前位置
  • Aggregate容器接口負責提供創(chuàng)建具體具體迭代器角色的接口
  • ConcreteAggregate具體容器類與具體迭代器角色相關聯(lián)
定義

迭代器模式提供一種方法順序訪問一個聚合對象中各個元素,而又不暴露對象的內(nèi)部表示。

使用場景

遍歷一個容器對象。

協(xié)作

ConcreteIterator跟蹤容器中的當前對象,并能夠計算出待遍歷的后繼對象。

示例代碼
//迭代器接口
public interface Iterator<T> {
    //是否有下一個元素
    boolean hasNext();
    //返回當前位置的元素,并將位置移到下一位
    T next();
}
//具體迭代器類
public class ConcreteIterator<T> implements Iterator<T> {
    private List<T> list = new ArrayList<>();
    private int cursor = 0;

    public ConcreteIterator(List<T> list) {
        this.list = list;
    }

    @Override
    public boolean hasNext() {
        return cursor != list.size();
    }

    @Override
    public T next() {
        T obj = null;
        if (this.hasNext()) obj = this.list.get(cursor++);
        return obj;
    }
}

//容器接口
public interface Aggregate<T> {
    //添加元素
    void add(T obj);
    //移除元素
    void remove(T obj);
    //獲取迭代器對象
    Iterator<T> iterator();
}
//具體容器類
public class ConcreteAggregate<T> implements Aggregate<T> {
    private List<T> list = new ArrayList<>();
    @Override
    public void add(T obj) {
        list.add(obj);
    }

    @Override
    public void remove(T obj) {
        list.remove(obj);
    }

    @Override
    public Iterator<T> iterator() {
        return new ConcreteIterator<T>(list);
    }
}
總結(jié)

遵循單一原則,弱化容器類與遍歷算法之間的關系。在客戶端與容器類之間添加一個迭代器類,可以不暴露容器類內(nèi)部的實現(xiàn),而得到容器類的元素。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

  • 1 場景問題# 1.1 工資表數(shù)據(jù)的整合## 考慮這樣一個實際應用:整合工資表數(shù)據(jù)。 這個項目的背景是這樣的,項目...
    七寸知架構(gòu)閱讀 2,645評論 0 53
  • 設計模式匯總 一、基礎知識 1. 設計模式概述 定義:設計模式(Design Pattern)是一套被反復使用、多...
    MinoyJet閱讀 4,094評論 1 15
  • 目錄 本文的結(jié)構(gòu)如下: 引言 什么是迭代器模式 模式的結(jié)構(gòu) 典型代碼 代碼示例 優(yōu)點和缺點 適用環(huán)境 模式應用 一...
    w1992wishes閱讀 607評論 0 1
  • 從三月份找實習到現(xiàn)在,面了一些公司,掛了不少,但最終還是拿到小米、百度、阿里、京東、新浪、CVTE、樂視家的研發(fā)崗...
    時芥藍閱讀 42,815評論 11 349
  • 本文參加#未完待續(xù),就要表白#活動,本人承諾,文章內(nèi)容為原創(chuàng),且未在其他平臺發(fā)表過。 時光匆匆如流水,一轉(zhuǎn)眼之間...
    20dd60d368be閱讀 330評論 0 0

友情鏈接更多精彩內(nèi)容