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

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

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

使用場(chǎng)景

遍歷一個(gè)容器對(duì)象。

協(xié)作

ConcreteIterator跟蹤容器中的當(dāng)前對(duì)象,并能夠計(jì)算出待遍歷的后繼對(duì)象。

示例代碼
//迭代器接口
public interface Iterator<T> {
    //是否有下一個(gè)元素
    boolean hasNext();
    //返回當(dāng)前位置的元素,并將位置移到下一位
    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);
    //獲取迭代器對(duì)象
    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é)

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

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

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

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

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