亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

Java設計模式之迭代器模式

2019-11-18 11:11:15
字體:
來源:轉載
供稿:網友
一、 引言

迭代這個名詞對于熟悉java的人來說絕對不生疏。我們經常使用JDK提供的迭代接口進行java collection的遍歷:

Iterator it = list.iterator();

while(it.hasNext()){

 //using “it.next();”do some businesss logic

}

而這就是關于迭代器模式應用很好的例子。

二、 定義與結構

迭代器(Iterator)模式,又叫做游標(Cursor)模式。GOF給出的定義為:提供一種方法訪問一個容器(container)對象中各個元素,而又不需暴露該對象的內部細節。

從定義可見,迭代器模式是為容器而生。很明顯,對容器對象的訪問必然涉及到遍歷算法。你可以一股腦的將遍歷方法塞到容器對象中去;或者根本不去提供什么遍歷算法,讓使用容器的人自己去實現去吧。這兩種情況似乎都能夠解決問題。

然而在前一種情況,容器承受了過多的功能,它不僅要負責自己“容器”內的元素維護(添加、刪除等等),而且還要提供遍歷自身的接口;而且由于遍歷狀態保存的問題,不能對同一個容器對象同時進行多個遍歷。第二種方式倒是省事,卻又將容器的內部細節暴露無遺。

而迭代器模式的出現,很好的解決了上面兩種情況的弊端。先來看下迭代器模式的真面目吧。

迭代器模式由以下角色組成:

1) 迭代器角色(Iterator):迭代器角色負責定義訪問和遍歷元素的接口。

2) 具體迭代器角色(Concrete Iterator):具體迭代器角色要實現迭代器接口,并要記錄遍歷中的當前位置。

3) 容器角色(Container):容器角色負責提供創建具體迭代器角色的接口。

4) 具體容器角色(Concrete Container):具體容器角色實現創建具體迭代器角色的接口——這個具體迭代器角色于該容器的結構相關。

迭代器模式的類圖如下:

Java設計模式之迭代器模式(圖一)

從結構上可以看出,迭代器模式在客戶與容器之間加入了迭代器角色。迭代器角色的加入,就可以很好的避免容器內部細節的暴露,而且也使得設計符號“單一職責原則”。

注重,在迭代器模式中,具體迭代器角色和具體容器角色是耦合在一起的——遍歷算法是與容器的內部細節緊密相關的。為了使客戶程序從與具體迭代器角色耦合的困境中脫離出來,避免具體迭代器角色的更換給客戶程序帶來的修改,迭代器模式抽象了具體迭代器角色,使得客戶程序更具一般性和重用性。這被稱為多態迭代。

三、 舉例

由于迭代器模式本身的規定比較松散,所以具體實現也就五花八門。我們在此僅舉一例,根本不能將實現方式一一呈現。因此在舉例前,我們先來列舉下迭代器模式的實現方式。

1.迭代器角色定義了遍歷的接口,但是沒有規定由誰來控制迭代。在Java collection的應用中,是由客戶程序來控制遍歷的進程,被稱為外部迭代器;還有一種實現方式便是由迭代器自身來控制迭代,被稱為內部迭代器。外部迭代器要比內部迭代器靈活、強大,而且內部迭代器在java語言環境中,可用性很弱。

2.在迭代器模式中沒有規定誰來實現遍歷算法。似乎理所當然的要在迭代器角色中實現。因為既便于一個容器上使用不同的遍歷算法,也便于將一種遍歷算法應用于不同的容器。但是這樣就破壞掉了容器的封裝——容器角色就要公開自己的私有屬性,在java中便意味著向其他類公開了自己的私有屬性。

那我們把它放到容器角色里來實現好了。這樣迭代器角色就被架空為僅僅存放一個遍歷當前位置的功能。但是遍歷算法便和特定的容器緊緊綁在一起了。

而在Java Collection的應用中,提供的具體迭代器角色是定義在容器角色中的內部類。這樣便保護了容器的封裝。但是同時容器也提供了遍歷算法接口,你可以擴展自己的迭代器。

好了,我們來看下Java Collection中的迭代器是怎么實現的吧。

//迭代器角色,僅僅定義了遍歷接口

public interface Iterator {

 boolean hasNext();

 Object next();

 void remove();

}

//容器角色,這里以List為例。它也僅僅是一個接口,就不羅列出來了

//具體容器角色,便是實現了List接口的ArrayList等類。為了突出重點這里指羅列和迭代器相關的內容

//具體迭代器角色,它是以內部類的形式出來的。AbstractList是為了將各個具體容器角色的公共部分提取出來而存在的。

public abstract class AbstractList extends AbstractCollection implements List {

……

//這個便是負責創建具體迭代器角色的工廠方法

public Iterator iterator() {

 return new Itr();

}

//作為內部類的具體迭代器角色

PRivate class Itr implements Iterator {

 int cursor = 0;

 int lastRet = -1;

 int eXPectedModCount = modCount;

 public boolean hasNext() {

return cursor != size();

 }

 public Object next() {

checkForComodification();

try {

 Object next = get(cursor);

 lastRet = cursor++;

 return next;

} catch(IndexOutOfBoundsException e) {

 checkForComodification();

 throw new NoSUChElementException();

}

 }

 public void remove() {

if (lastRet == -1)

 throw new IllegalStateException();

 checkForComodification();

try {

 AbstractList.this.remove(lastRet);

 if (lastRet < cursor)

cursor--;

 lastRet = -1;

 expectedModCount = modCount;

} catch(IndexOutOfBoundsException e) {

 throw new ConcurrentModificationException();

}

 }

 final void checkForComodification() {

if (modCount != expectedModCount)

 throw new ConcurrentModificationException();

 }

}

至于迭代器模式的使用。正如引言中所列那樣,客戶程序要先得到具體容器角色,然后再通過具體容器角色得到具體迭代器角色。這樣便可以使用具體迭代器角色來遍歷容器了……

四、 實現自己的迭代器

在實現自己的迭代器的時候,一般要操作的容器有支持的接口才可以。而且我們還要注重以下問題:

在迭代器遍歷的過程中,通過該迭代器進行容器元素的增減操作是否安全呢?

在容器中存在復合對象的情況,迭代器怎樣才能支持深層遍歷和多種遍歷呢?

以上兩個問題對于不同結構的容器角色,各不相同,值得考慮。

五、 適用情況



由上面的講述,我們可以看出迭代器模式給容器的應用帶來以下好處:

1) 支持以不同的方式遍歷一個容器角色。根據實現方式的不同,效果上會有差別。

2) 簡化了容器的接口。但是在java Collection中為了提高可擴展性,容器還是提供了遍歷的接口。

3) 對同一個容器對象,可以同時進行多個遍歷。因為遍歷狀態是保存在每一個迭代器對象中的。

由此也能得出迭代器模式的適用范圍:

1) 訪問一個容器對象的內容而無需暴露它的內部表示。

2) 支持對容器對象的多種遍歷。

3) 為遍歷不同的容器結構提供一個統一的接口(多態迭代)。

六、 總結

迭代器模式在我們的應用中很廣泛,希望本文能幫助你理解它。如有不對之處,還請不吝指正。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
精品自拍视频在线观看| 一本色道久久88综合日韩精品| 国产亚洲人成a一在线v站| 午夜精品理论片| 久久乐国产精品| 日韩在线观看免费av| 狠狠久久五月精品中文字幕| 国产在线日韩在线| 欧美日韩另类字幕中文| 亚洲综合精品一区二区| 欧美午夜宅男影院在线观看| 美日韩精品免费视频| 亚洲美女av在线播放| 国产91在线播放九色快色| 不卡伊人av在线播放| 亚洲丁香久久久| 中文字幕亚洲第一| 国产精品自拍小视频| 伦伦影院午夜日韩欧美限制| 国产一区二区三区18| 欧美激情奇米色| 久久久久久国产精品久久| 久久好看免费视频| 91精品久久久久久久久| 欧美老妇交乱视频| 尤物yw午夜国产精品视频明星| 91国自产精品中文字幕亚洲| 亚洲电影免费观看高清完整版在线观看| 最好看的2019年中文视频| 日韩国产精品视频| 91丝袜美腿美女视频网站| 91精品在线观| 国产一区二区三区精品久久久| 久久久久亚洲精品国产| 久久久精品一区二区三区| 日本久久久久亚洲中字幕| 欧美午夜电影在线| 国产日韩欧美在线| 国产女同一区二区| 欧美视频一区二区三区…| 97在线观看视频国产| xxxx欧美18另类的高清| 在线视频日本亚洲性| 九九九热精品免费视频观看网站| 亚洲第一福利网站| 日韩av毛片网| 久久久欧美一区二区| 亚洲第一视频在线观看| 国产精品jvid在线观看蜜臀| 日韩欧美精品免费在线| 国产精品成人v| 国产精品电影久久久久电影网| 欧美有码在线观看视频| 国产精品观看在线亚洲人成网| 性欧美办公室18xxxxhd| 亚洲国产精品99久久| 正在播放欧美视频| 黑人巨大精品欧美一区二区| 国产一区二区三区视频在线观看| 欧美有码在线观看| 欧美日韩精品国产| 国产综合在线看| 日韩av资源在线播放| 亚洲欧美日韩成人| 精品视频久久久久久久| 欧美激情一区二区三区高清视频| 色综久久综合桃花网| 尤物yw午夜国产精品视频明星| 亚洲的天堂在线中文字幕| 狠狠躁夜夜躁人人躁婷婷91| 欧美精品久久久久a| 日韩久久免费视频| 在线观看国产欧美| 中文日韩在线观看| 日本久久久久久久| 欧美日韩成人免费| 一区二区三区四区精品| 久久久久久久国产| 日韩激情视频在线播放| 国产欧美va欧美va香蕉在| 亚洲精品午夜精品| 欧美性猛交xxxx乱大交3| 日韩av黄色在线观看| 欧美极品少妇xxxxⅹ裸体艺术| 青草成人免费视频| 久久精品国产精品| 最好看的2019的中文字幕视频| 久久夜精品香蕉| 中文字幕日韩欧美精品在线观看| 欧美激情欧美狂野欧美精品| 久久久久久久久久久网站| 成人黄色av网站| 国产精品igao视频| 欧美性生交xxxxx久久久| 欧美日韩激情视频| 亚洲午夜性刺激影院| 一本色道久久综合狠狠躁篇怎么玩| 日韩精品免费电影| 亚洲国产日韩欧美在线动漫| 欧美激情综合色综合啪啪五月| 国产福利视频一区二区| 欧美激情久久久久久| 97av在线播放| 午夜精品一区二区三区视频免费看| 午夜精品久久久99热福利| 国模精品视频一区二区三区| 91在线视频导航| 97在线视频免费| 日韩精品中文字幕在线播放| 国产偷国产偷亚洲清高网站| 欧美亚洲另类制服自拍| 日韩电影中文字幕在线| 中文字幕精品影院| 欧美国产日韩一区二区| 亚洲高清在线观看| 欧美另类交人妖| 蜜月aⅴ免费一区二区三区| 欧美成人一区在线| 国产美女久久精品香蕉69| 欧美午夜精品久久久久久人妖| 亚洲香蕉av在线一区二区三区| 亚洲a在线观看| 成人亚洲综合色就1024| 欧美高清在线观看| 亚洲男子天堂网| 欧美中文字幕视频在线观看| 欧美在线性爱视频| 国产精品普通话| 欧美乱大交xxxxx另类电影| 国产精品国产福利国产秒拍| 国产精品视频一| 日本一区二区三区在线播放| 91午夜在线播放| 国产成人极品视频| 中文字幕日韩欧美精品在线观看| 亚洲qvod图片区电影| 精品国产一区二区三区在线观看| 日韩女优人人人人射在线视频| 中文字幕亚洲欧美一区二区三区| 欧美乱大交xxxxx另类电影| 亚洲视频在线观看视频| 欧美电影院免费观看| 日韩成人av网址| www.99久久热国产日韩欧美.com| 日韩精品欧美激情| 最近2019中文字幕大全第二页| 欧美成人一区在线| 亚洲自拍偷拍视频| 日韩欧美成人免费视频| 欧美xxxx18性欧美| 亚洲成人aaa| 久久人人爽人人爽人人片亚洲| 日韩美女福利视频| 亚洲国产精彩中文乱码av在线播放| 91香蕉电影院| 日韩在线播放视频| 国产91亚洲精品| 中文字幕日韩有码| 亚洲欧美精品在线| 97人洗澡人人免费公开视频碰碰碰| 91亚洲永久免费精品| 久久夜色精品国产| 日韩av最新在线观看| 亚洲xxxxx性|