設計模式之迭代器模式

2022-09-02 12:48:10 字數 1074 閱讀 7656

【定義】迭代器模式(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...