程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> PHP設計模式漫談之迭代器模式(3)

PHP設計模式漫談之迭代器模式(3)

編輯:關於PHP編程

注意,迭代器是比對象集更好的抽象,因為我們可以讓InfiniteIterators,NoRewindIterators等,不用與普通數組陣列與一致,因此,Iterator缺少count()函數等功能。
在PHP官方手冊中可以找到完整的SPL迭代器列表。得益於對PHP的強力支持,使用迭代器模式的大部分工作都包括在標准實現中,下面的代碼示例就利用了標准Iterator和RecursiveIterators的功能。

___FCKpd___0/**   * Usually IteratorAggregate is the interface to implement.   * It has only one method, which must return an Iterator   * already defined as another class (e.g. ArrayIterator)   * Iterator gives a finer control over the algorithm,   * because all the hook points of Iterator contract   * are available for implementation.   */  class NumbersSet implements IteratorAggregate  {   

   private 今天《PHP設計模式漫談》系列的主角是迭代器(Iterator)模式,它在一個很常見的過程上提供了一個抽象:位於對象圖不明部分的一組對象(或標量)集合上的迭代。迭代有幾種不同的具體執行方法:在數組屬性,集合對象,數組,甚至一個查詢結果集之上迭代。


在對象的世界裡,迭代器模式要維持類似數組的功能,看作是一個非侵入性對象刻面(facet),Client類往往分離自真實對象實現,指iterator接口。只要有可能,我們可以給迭代器傳送一個引用,代替將來可能發生變化的迭代器模式具體或抽象類。
 圖1 迭代器模式
參與者:
◆客戶端(Client):引用迭代器模式的方法在一組值或對象上執行一個循環。
◆迭代器(Iterator):在迭代過程上的抽象,包括next(),isFinished(),current()等方法。
◆具體迭代器(ConcreteIterators):在一個特定的對象集,如數組,樹,組合,集合等上實現迭代。
通過Traversable接口,PHP原生態支持迭代器模式,這個接口由Iterator和IteratorAggregate做了擴展,這兩個子接口不僅是定義了一套標准的方法,每個Traversable對象都可以原封不動地傳遞給foreach(),foreach是迭代器的主要客戶端,Iterator實現是真正的迭代器,而IteratorAggregate是有其它職責的Traversable對象,它通過getIterator()方法返回一個Iterator。

PHP架構

標准PHP庫是PHP中綁定的唯一通用目的面向對象庫,定義了額外的接口和公用類。OuterIterator實現裝飾一個Iterator,CachingIterator和LimitIterator是這個接口的兩個例子。
RecursiveIterator是Iterator接口為樹形結構實現的一個擴展,它定義了一組額外的方法檢查迭代中當前元素的子對象是否存在。RecursiveArrayIterator和RecursiveDirectoryIterator是這個接口的實現示例,這些類型的迭代器可以原樣使用,或是用一個RecursiveIteratorIterator橋接到一個普通的迭代器契約。這個OuterIterator實現將會根據構造參數執行深度優先或廣度優先遍歷。
使用RecursiveIteratorIterator時,可以將其傳遞給foreach,請看後面的代碼示例,了解RecursiveIterators的不同用法和它們的超集Iterator。最後,SeekableIterators向契約添加了一個seek()方法,它可以用於移動Iterator的內部狀態到一個特定的迭代點。

 

 

 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved