**實現
它提供一種方法訪問乙個容器物件中各個元素, 而又不需暴露該物件的內部細節。注意這裡的設計模式需要關注的重點是如何建立乙個迭代器,還有我們使用的集合物件是定義在**?。
具有我們想要遍歷的集合屬性,同時也定義了判斷位置的游標
負責提供上面定義的抽象迭代器
具體容器實現容器介面定義的方法, 建立出容納迭代器的物件。在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...