來源:不言 發(fā)布時間:2018-08-13 09:48:30 閱讀量:765
本篇文章給大家?guī)淼膬?nèi)容是關(guān)于PHP中迭代器以及生成器的分析以及優(yōu)缺點(diǎn)的介紹,有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。
一.迭代器
分析:想一下,如果把集合對象和對集合對象的操作放在一起,當(dāng)我們想換一種方式遍歷集合對象中元素時,就需要修改集合對象了,違背“單一職責(zé)原則”,而迭代器模式將數(shù)據(jù)結(jié)構(gòu)和數(shù)據(jù)結(jié)構(gòu)的算法分離開,兩者可獨(dú)立發(fā)展。
優(yōu)點(diǎn):
1.支持多種遍歷方式。比如有序列表,我們根據(jù)需要提供正序遍歷、倒序遍歷兩種迭代器。用戶只需要得到我們的迭代器,就可以對集合執(zhí)行遍歷操作
2.簡化了聚合類。由于引入了迭代器,原有的集合對象不需要自行遍歷集合元素了
3.增加新的聚合類和迭代器類很方便,兩個維度上可各自獨(dú)立變化
4.為不同的集合結(jié)構(gòu)提供一個統(tǒng)一的接口,從而支持同樣的算法在不同的集合結(jié)構(gòu)上操作
缺點(diǎn):
1.迭代器模式將存儲數(shù)據(jù)和遍歷數(shù)據(jù)的職責(zé)分離增加新的集合對象時需要增加對應(yīng)的迭代器類,類的個數(shù)成對增加,在一定程度上增加系統(tǒng)復(fù)雜度
具體接口:
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引入的功能,與標(biāo)準(zhǔn)的PHP迭代器不同,PHP生成器不要求類實(shí)現(xiàn)Iterator接口,從而減輕了類的負(fù)擔(dān),生成器會根據(jù)需求計算并產(chǎn)出要迭代的值,這對性能有重大的影響試想一下假如標(biāo)準(zhǔn)的PHP迭代器經(jīng)常在內(nèi)存中執(zhí)行迭代操作者要預(yù)先計算出數(shù)據(jù)集性能低下;如果要使用特定的的方式對計算大量數(shù)據(jù),對性能的影響更甚。此時我們可以使用生成器,即時計算產(chǎn)出后續(xù)值不占用寶貴的內(nèi)存資源。
優(yōu)點(diǎn):占用內(nèi)存少對,性能好。每次產(chǎn)出一個值之后,生成器的內(nèi)部狀態(tài)都會停頓;當(dāng)生成器請求下一個值時,內(nèi)部狀態(tài)又會恢復(fù)。生成器的內(nèi)部一直在停頓和恢復(fù)之間切換,直到循環(huán)完成或停頓位置
缺點(diǎn):
1.PHP生成器不能滿足所有迭代器的需求,因?yàn)槿绻徊樵?,生成器永遠(yuǎn)不知道下一個要迭代的值是什么,在生成器中無法后退或前進(jìn)。
2.生成器還是一次性的,無法多次迭代同一個生成器,不過,如果需要,可以重建或克隆生成器。
創(chuàng)建生成器:
1.因?yàn)樯善骶褪荘HP函數(shù),生成器就是在函數(shù)中使用yield關(guān)鍵字。與普通的PHP函數(shù)不同的是,生產(chǎn)器從不返回值,只產(chǎn)出值。
<?php
function
myGenerator(){
yield
'a'
;
yield
'b'
;
yield
'c'
;
}
2.調(diào)用生成器函數(shù)時,PHP會返回一個屬于Generator類的對象。這個對象可以使用foreach()函數(shù)迭代。每次迭代,PHP會要求Generator實(shí)例計算并提供下一個要迭代的值
<?php
function
makeRange(
$length
){
for
(
$i
= 0;
$i
<
$length
;
$i
++){
yield
$i
;
}
}
foreach
(makeRange(1000000)
as
$i
){
echo
$i
,PHP_EOL;
}
如上所示:當(dāng)$length 很大時(上百萬),而且你同時沒有使用生成器的話,那么就要預(yù)先為一個由一百萬上一千五個整數(shù)組成的數(shù)組分配內(nèi)存。而PHP生成器能實(shí)現(xiàn)相同的操作,不過一次只會為一個整數(shù)分配內(nèi)存
相關(guān)推薦:
php使用位運(yùn)算實(shí)現(xiàn)整數(shù)的加減乘除并測試(代碼示例)
PHP和html表單之間實(shí)現(xiàn)簡單交互的代碼
以上就是PHP中迭代器以及生成器的分析以及優(yōu)缺點(diǎn)的介紹的詳細(xì)內(nèi)容,更多請關(guān)注php中文網(wǎng)其它相關(guān)文章!