【定義】迭代器模式(iterator),提供一種方法順序訪問乙個聚合物件中的各個元素,而又不暴露該物件的內部表示。
【場景】下面是乙個int型的陣列,這裡實現乙個遍歷該陣列的迭代器。如果又有乙個新的陣列,而陣列裡面的資料是class car,則實現乙個class cararray即可,迭代器類是基於模版的,即array的資料型別是無關的。
【uml】
【**】
/** iterator.h
*/#ifndef __iterator_h__
#define __iterator_h__
#define max_data_num 0x20
class intarray;
templateclass iterator
;class intiterator : public iterator;
class intarray
;#endif
/** iterator.cpp
*/#include #include #include "iterator.h"
using namespace std;
intiterator::intiterator(intarray* i):intarray(i),count(0)
int intiterator::get_first()
int intiterator::get_next()
intarray::intarray()
iterator = new intiterator(this);
}intarray::~intarray()
intiterator* intarray:: get_iterator()
int main()
{ iterator* iterator = null;
intarray* intarray = new intarray();
iterator = intarray->get_iterator();
cout
cout
cout
設計模式之迭代器模式
概念 提供一種方法順序訪問乙個聚合物件中各個元素,而又不需暴露該物件的內部表示。main 客戶 iproject,產品介面 cproject,產品類 iiterator,迭代器介面 iprojectiterator,產品迭代器介面 cprojectiterator,產品迭代器實現類 說明 cproj...
設計模式之迭代器模式
當你需要訪問乙個聚集物件,而且不管這些物件是什麼都需要遍歷的時候,而且可能對聚集有多種方式遍歷時,需要為遍歷不同的聚集結構提供如開始,下乙個,是否結束,當前哪一項等 統一介面,你就應該考慮用迭代器模式.提供一種方法順序訪問乙個聚合物件中各個元素,而又不暴露該物件的內部表示.uml設計圖 部分 ite...
設計模式之迭代器模式
說起迭代器,大家一定不陌生,經常使用的foreach in 這種迴圈就是,c 語言已經內建化了迭代器模式,主要是支援對非泛型集合的簡單迭代介面ieumerator和公開列舉數ienumerable。雖然內建了,但是這種模式也有我們學習的必要性。如下 using system using system...