迭代器模式

描述

????迭代模式是對(duì)象的行為模式裆蒸。迭代模式可以順序訪問(wèn)集合對(duì)象的元素,不需要知道集合對(duì)象的底層表示。

簡(jiǎn)介

迭代器類(lèi)圖

????迭代器模式是通過(guò)將聚合對(duì)象的遍歷行為分離出來(lái),抽象成迭代器類(lèi)來(lái)實(shí)現(xiàn)的斋竞,其目的是在不暴露聚合對(duì)象的內(nèi)部結(jié)構(gòu)的情況下,讓外部代碼透明地訪問(wèn)聚合的內(nèi)部數(shù)據(jù)⊥貉常現(xiàn)在我們來(lái)分析其基本結(jié)構(gòu)與實(shí)現(xiàn)方法坝初。

角色

  • 抽象聚合(Aggregate)角色:定義存儲(chǔ)、添加钾军、刪除聚合對(duì)象以及創(chuàng)建迭代器對(duì)象的接口鳄袍。
  • 具體聚合(ConcreteAggregate)角色:實(shí)現(xiàn)抽象聚合類(lèi),返回一個(gè)具體迭代器的實(shí)例吏恭。
  • 抽象迭代器(Iterator)角色:定義訪問(wèn)和遍歷聚合元素的接口拗小,通常包含 hasNext()、first()砸泛、next() 等方法十籍。
  • 具體迭代器(Concretelterator)角色:實(shí)現(xiàn)抽象迭代器接口中所定義的方法,完成對(duì)聚合對(duì)象的遍歷唇礁,記錄遍歷的當(dāng)前位置。

優(yōu)缺點(diǎn)

優(yōu)點(diǎn)

  • 訪問(wèn)一個(gè)聚合對(duì)象的內(nèi)容而無(wú)須暴露它的內(nèi)部表示惨篱。
  • 遍歷任務(wù)交由迭代器完成盏筐,這簡(jiǎn)化了聚合類(lèi)。
  • 它支持以不同方式遍歷一個(gè)聚合砸讳,甚至可以自定義迭代器的子類(lèi)以支持新的遍歷琢融。
  • 增加新的聚合類(lèi)和迭代器類(lèi)都很方便,無(wú)須修改原有代碼簿寂。
  • 封裝性良好漾抬,為遍歷不同的聚合結(jié)構(gòu)提供一個(gè)統(tǒng)一的接口。

缺點(diǎn)

  • 增加了類(lèi)的個(gè)數(shù)常遂,這在一定程度上增加了系統(tǒng)的復(fù)雜性纳令。

使用場(chǎng)景

  • 訪問(wèn)一個(gè)聚合對(duì)象的內(nèi)容而無(wú)須暴露它的內(nèi)部表示。
  • 需要為聚合對(duì)象提供多種遍歷方式克胳。
  • 為遍歷不同的聚合結(jié)構(gòu)提供一個(gè)統(tǒng)一的接口平绩。

示例

/**
* 抽象聚合(Aggregate)角色
*/
public interface Aggregate {
   void add(Object obj);
   void remove(Object obj);
   Iterator getIterator();
}
/**
* 具體聚合(ConcreteAggregate)角色
*/
public class ConcreteAggregate implements Aggregate {
   private List<Object> list = new ArrayList<Object>();

   @Override
   public void add(Object obj) {
       list.add(obj);
   }

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

   @Override
   public Iterator getIterator() {
       return (new ConcreteIterator(list));
   }
}
/**
* 抽象迭代器(Iterator)角色
*/
public interface Iterator {
   Object first();
   Object next();
   boolean hasNext();
}
/**
* 具體迭代器(Concretelterator)角色
*/
public class ConcreteIterator implements Iterator {
   private List<Object> list = null;
   private int index = -1;

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

   @Override
   public boolean hasNext() {
       if (index < list.size() - 1) {
           return true;
       } else {
           return false;
       }
   }

   @Override
   public Object first() {
       index = 0;
       Object obj = list.get(index);
       return obj;
   }

   @Override
   public Object next() {
       Object obj = null;
       if (this.hasNext()) {
           obj = list.get(++index);
       }
       return obj;
   }
}
/**
* 客戶端
*/
public class Client {
   public static void main(String[] args) {
       Aggregate ag = new ConcreteAggregate();
       ag.add("紅");
       ag.add("黃");
       ag.add("藍(lán)");
       ag.add("綠");
       System.out.print("聚合的內(nèi)容有:");
       Iterator it = ag.getIterator();
       while (it.hasNext()) {
           Object ob = it.next();
           System.out.print(ob.toString() + "\t");
       }
       Object ob = it.first();
       System.out.println("\nFirst:" + ob.toString());
   }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市漠另,隨后出現(xiàn)的幾起案子捏雌,更是在濱河造成了極大的恐慌,老刑警劉巖笆搓,帶你破解...
    沈念sama閱讀 211,639評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件性湿,死亡現(xiàn)場(chǎng)離奇詭異纬傲,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)肤频,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,277評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén)嘹锁,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人着裹,你說(shuō)我怎么就攤上這事领猾。” “怎么了骇扇?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,221評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵摔竿,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我少孝,道長(zhǎng)继低,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,474評(píng)論 1 283
  • 正文 為了忘掉前任稍走,我火速辦了婚禮袁翁,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘婿脸。我一直安慰自己粱胜,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,570評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布狐树。 她就那樣靜靜地躺著焙压,像睡著了一般。 火紅的嫁衣襯著肌膚如雪抑钟。 梳的紋絲不亂的頭發(fā)上涯曲,一...
    開(kāi)封第一講書(shū)人閱讀 49,816評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音在塔,去河邊找鬼幻件。 笑死,一個(gè)胖子當(dāng)著我的面吹牛蛔溃,可吹牛的內(nèi)容都是我干的绰沥。 我是一名探鬼主播,決...
    沈念sama閱讀 38,957評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼城榛,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼揪利!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起狠持,我...
    開(kāi)封第一講書(shū)人閱讀 37,718評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤疟位,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后喘垂,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體甜刻,經(jīng)...
    沈念sama閱讀 44,176評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡绍撞,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,511評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了得院。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片傻铣。...
    茶點(diǎn)故事閱讀 38,646評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖祥绞,靈堂內(nèi)的尸體忽然破棺而出非洲,到底是詐尸還是另有隱情,我是刑警寧澤蜕径,帶...
    沈念sama閱讀 34,322評(píng)論 4 330
  • 正文 年R本政府宣布两踏,位于F島的核電站,受9級(jí)特大地震影響兜喻,放射性物質(zhì)發(fā)生泄漏梦染。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,934評(píng)論 3 313
  • 文/蒙蒙 一朴皆、第九天 我趴在偏房一處隱蔽的房頂上張望帕识。 院中可真熱鬧,春花似錦遂铡、人聲如沸肮疗。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,755評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)族吻。三九已至,卻和暖如春珠增,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背砍艾。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,987評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工蒂教, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人脆荷。 一個(gè)月前我還...
    沈念sama閱讀 46,358評(píng)論 2 360
  • 正文 我出身青樓凝垛,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親蜓谋。 傳聞我的和親對(duì)象是個(gè)殘疾皇子梦皮,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,514評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容