本篇文章給大家帶來的內容是關於PHP中迭代器以及產生器的分析以及優缺點的介紹,有一定的參考價值,有需要的朋友可以參考一下,希望對你有所協助。
一.迭代器
分析:想一下,如果把集合對象和對集合對象的操作放在一起,當我們想換一種方式遍曆集合對象中元素時,就需要修改集合對象了,違背“單一職責原則”,而迭代器模式將資料結構和資料結構的演算法分離開,兩者可獨立發展。
優點:
1.支援多種遍曆方式。比如有序列表,我們根據需要提供正序遍曆、倒序遍曆兩種迭代器。使用者只需要得到我們的迭代器,就可以對集合執行遍曆操作
2.簡化了彙總類。由於引入了迭代器,原有的集合對象不需要自行遍曆集合元素了
3.增加新的彙總類和迭代器類很方便,兩個維度上可各自獨立變化
4.為不同的集合結構提供一個統一的介面,從而支援同樣的演算法在不同的集合結構上操作
缺點:
1.迭代器模式將儲存資料和遍曆資料的職責分離增加新的集合對象時需要增加對應的迭代器類,類的個數成對增加,在一定程度上增加系統複雜度
具體介面:
Iterator extends Traversable {/* 方法 */abstract public mixed current ( void )abstract public scalar key ( void )abstract public void next ( void )abstract public void rewind ( void )abstract public bool valid ( void )}
二.產生器
PHP產生器(generator)是PHP5.5.0引入的功能,與標準的PHP迭代器不同,PHP產生器不要求類實現Iterator介面,從而減輕了類的負擔,產生器會根據需求計算併產出要迭代的值,這對效能有重大的影響試想一下假如標準的PHP迭代器經常在記憶體中執行迭代操作者要預先計算出資料集效能低下;如果要使用特定的的方式對計算大量資料,對效能的影響更甚。此時我們可以使用產生器,即時計算產出後續值不佔用寶貴的記憶體資源。
優點:佔用記憶體少對,效能好。每次產出一個值之後,產生器的內部狀態都會停頓;當產生器請求下一個值時,內部狀態又會恢複。產生器的內部一直在停頓和恢複之間切換,直到迴圈完成或停頓位置
缺點:
1.PHP產生器不能滿足所有迭代器的需求,因為如果不查詢,產生器永遠不知道下一個要迭代的值是什麼,在產生器中無法後退或前進。
2.產生器還是一次性的,無法多次迭代同一個產生器,不過,如果需要,可以重建或複製產生器。
建立產生器:
1.因為產生器就是PHP函數,產生器就是在函數中使用yield關鍵字。與普通的PHP函數不同的是,生產器從不傳回值,只產出值。
<?phpfunction myGenerator(){ yield 'a'; yield 'b'; yield 'c';}
2.調用產生器函數時,PHP會返回一個屬於Generator類的對象。這個對象可以使用foreach()函數迭代。每次迭代,PHP會要求Generator執行個體計算並提供下一個要迭代的值
<?phpfunction makeRange($length){ for($i = 0; $i<$length; $i++){ yield $i; }}foreach(makeRange(1000000) as $i){ echo $i,PHP_EOL;}
如上所示:當$length 很大時(上百萬),而且你同時沒有使用產生器的話,那麼就要預先為一個由一百萬上一千五個整數組成的數組分配記憶體。而PHP產生器能實現相同的操作,不過一次只會為一個整數分配記憶體