設計模式之迭代器模式

2021-10-22 20:54:50 字數 971 閱讀 5984

**實現

它提供一種方法訪問乙個容器物件中各個元素, 而又不需暴露該物件的內部細節。注意這裡的設計模式需要關注的重點是如何建立乙個迭代器,還有我們使用的集合物件是定義在**?。

具有我們想要遍歷的集合屬性,同時也定義了判斷位置的游標

負責提供上面定義的抽象迭代器

具體容器實現容器介面定義的方法, 建立出容納迭代器的物件。在iterator()中實現(new concreteiterator(vector _vector); )

public

inte***ce

iterator

public

class

concreteiterator

implements

iterator

//判斷是否到達尾部

public

boolean

hasnext()

else

}//返回下乙個元素

public object next()

else

return result;

}//刪除當前元素

public

boolean

remove()

}

public

inte***ce

aggregate

public

class

concreteaggregate

implements

aggregate

//返回迭代器物件

public iterator iterator()

//刪除乙個元素

public

void

remove

(object object)

}

設計模式之迭代器模式

概念 提供一種方法順序訪問乙個聚合物件中各個元素,而又不需暴露該物件的內部表示。main 客戶 iproject,產品介面 cproject,產品類 iiterator,迭代器介面 iprojectiterator,產品迭代器介面 cprojectiterator,產品迭代器實現類 說明 cproj...

設計模式之迭代器模式

當你需要訪問乙個聚集物件,而且不管這些物件是什麼都需要遍歷的時候,而且可能對聚集有多種方式遍歷時,需要為遍歷不同的聚集結構提供如開始,下乙個,是否結束,當前哪一項等 統一介面,你就應該考慮用迭代器模式.提供一種方法順序訪問乙個聚合物件中各個元素,而又不暴露該物件的內部表示.uml設計圖 部分 ite...

設計模式之迭代器模式

說起迭代器,大家一定不陌生,經常使用的foreach in 這種迴圈就是,c 語言已經內建化了迭代器模式,主要是支援對非泛型集合的簡單迭代介面ieumerator和公開列舉數ienumerable。雖然內建了,但是這種模式也有我們學習的必要性。如下 using system using system...