麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發 > Java > 正文

詳解Java設計模式——迭代器模式

2024-07-14 08:43:36
字體:
來源:轉載
供稿:網友

迭代子模式

顧名思義,迭代器模式就是順序訪問聚集中的對象,一般來說,集合中非常常見,如果對集合類比較熟悉的話,理解本模式會十分輕松。這句話包含兩層意思:一是需要遍歷的對象,即聚集對象,二是迭代器對象,用于對聚集對象進行遍歷訪問。我們看下關系圖:

Java,設計模式,迭代器模式

這個思路和我們常用的一模一樣,MyCollection中定義了集合的一些操作,MyIterator中定義了一系列迭代操作,且持有Collection實例,我們來看看實現代碼:
兩個接口:

public interface Collection {   public Iterator iterator();   /*取得集合元素*/  public Object get(int i);   /*取得集合大小*/  public int size(); } public interface Iterator {  //前移  public Object previous();   //后移  public Object next();  public boolean hasNext();   //取得第一個元素  public Object first(); } 

兩個實現:

public class MyCollection implements Collection {   public String string[] = {"A","B","C","D","E"};  @Override  public Iterator iterator() {  return new MyIterator(this);  }   @Override  public Object get(int i) {  return string[i];  }   @Override  public int size() {  return string.length;  } } public class MyIterator implements Iterator {   private Collection collection;  private int pos = -1;   public MyIterator(Collection collection){  this.collection = collection;  }   @Override  public Object previous() {  if(pos > 0){  pos--;  }  return collection.get(pos);  }   @Override  public Object next() {  if(pos<collection.size()-1){  pos++;  }  return collection.get(pos);  }   @Override  public boolean hasNext() {  if(pos<collection.size()-1){  return true;  }else{  return false;  }  }   @Override  public Object first() {  pos = 0;  return collection.get(pos);  }  } 

測試類:

public class Test {   public static void main(String[] args) {  Collection collection = new MyCollection();  Iterator it = collection.iterator();   while(it.hasNext()){  System.out.println(it.next());  }  } } 

此處我們貌似模擬了一個集合類的過程,感覺是不是很爽?其實JDK中各個類也都是這些基本的東西,加一些設計模式,再加一些優化放到一起的,只要我們把這些東西學會了,掌握好了,我們也可以寫出自己的集合類,甚至框架!

介紹
意圖:提供一種方法順序訪問一個聚合對象中各個元素, 而又無須暴露該對象的內部表示。

主要解決:不同的方式來遍歷整個整合對象。

何時使用:遍歷一個聚合對象。

如何解決:把在元素之間游走的責任交給迭代器,而不是聚合對象。

關鍵代碼:定義接口:hasNext, next。

應用實例:JAVA 中的 iterator。

優點:

1、它支持以不同的方式遍歷一個聚合對象。

2、迭代器簡化了聚合類。

3、在同一個聚合上可以有多個遍歷。

4、在迭代器模式中,增加新的聚合類和迭代器類都很方便,無須修改原有代碼。

缺點:由于迭代器模式將存儲數據和遍歷數據的職責分離,增加新的聚合類需要對應增加新的迭代器類,類的個數成對增加,這在一定程度上增加了系統的復雜性。

使用場景:

1、訪問一個聚合對象的內容而無須暴露它的內部表示。

2、需要為聚合對象提供多種遍歷方式。

3、為遍歷不同的聚合結構提供一個統一的接口。

注意事項:迭代器模式就是分離了集合對象的遍歷行為,抽象出一個迭代器類來負責,這樣既可以做到不暴露集合的內部結構,又可讓外部代碼透明地訪問集合內部的數據。

以上所述是小編給大家介紹的Java設計模式——迭代器模式詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VeVb武林網網站的支持!


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 人人舔人人舔 | 污黄视频在线播放 | 国产乱淫a∨片免费视频 | www.精品视频| 一级一级一级毛片 | 一级黄色欧美 | 91短视频在线播放 | 性插视频 | 精品国产高清一区二区三区 | 爱高潮www亚洲精品 国产精品一区自拍 | 中文字幕在线观看精品 | 久久久久久艹 | 国产超碰人人爽人人做人人爱 | 久草在线最新 | 免费一区二区三区 | 久久久久女人精品毛片九一 | 中文字幕观看 | 逼片| 日韩av电影免费看 | 国产69精品久久久久久久久久 | 毛片免费在线 | 九色国产 | 3xxx| 国产精品一区二区三区在线播放 | 国产精品久久久久久久久久iiiii | 91超在线 | 国产一区二区三区四区五区在线 | 羞羞视频免费观看网站 | 色诱亚洲精品久久久久久 | 久久精品亚洲精品国产欧美kt∨ | 香蕉久久久久 | 国产成年人视频 | 国产精品7区 | 欧美性生活久久久 | 国产亚洲精品久久午夜玫瑰园 | 免费看成年人网站 | 福利在线国产 | 国产91大片 | av在线播放亚洲 | 国产精品自在线拍 | 亚洲一区在线免费视频 |