迭代器有時(shí)又稱光標(biāo)(cursor)是程式設(shè)計(jì)的軟件設(shè)計(jì)模式,可在容器物件(container,例如list或vector)上遍訪的接口,設(shè)計(jì)人員無(wú)需關(guān)心容器物件的內(nèi)容。
各種語(yǔ)言實(shí)作Iterator的方式皆不盡同,有些面向?qū)ο笳Z(yǔ)言像Java, C#, Python, Delphi都已將Iterator的特性內(nèi)建語(yǔ)言當(dāng)中,完美的跟語(yǔ)言整合,我們稱之隱式迭代器(implicit iterator),但像是C++語(yǔ)言本身就沒(méi)有Iterator的特色,但STL仍利用template實(shí)作了功能強(qiáng)大的iterator。
PHP5開(kāi)始支持了接口, 并且內(nèi)置了Iterator接口, 所以如果你定義了一個(gè)類,并實(shí)現(xiàn)了Iterator接口,那么你的這個(gè)類對(duì)象就是ZEND_ITER_OBJECT
,否則就是ZEND_ITER_PLAIN_OBJECT
.
對(duì)于ZEND_ITER_PLAIN_OBJECT
的類,foreach會(huì)通過(guò)HASH_OF
獲取該對(duì)象的默認(rèn)屬性數(shù)組,然后對(duì)該數(shù)組進(jìn)行foreach.
先來(lái)看下迭代器的定義,那就是提供一種方法順序訪問(wèn)一個(gè)聚合對(duì)象中各個(gè)元素,而又不暴露該對(duì)象的內(nèi)部顯示。它可幫助構(gòu)造特定的對(duì)象,那些對(duì)象能夠提供單一標(biāo)準(zhǔn)接口循環(huán)或迭代任何類型的可計(jì)數(shù)數(shù)據(jù)。來(lái)看下迭代器模式的結(jié)構(gòu)圖:

再來(lái)看下迭代器需要用到的內(nèi)部方法:
- Iterator::current — Return the current element 返回當(dāng)前元素
- Iterator::key — Return the key of the current element 返回當(dāng)前元素的鍵
- Iterator::next — Move forward to next element 移向下一個(gè)元素
- Iterator::rewind — Rewind the Iterator to the first element 重新回到第一個(gè)元素
- Iterator::valid — Checks if current position is valid 檢查當(dāng)前位置的有效性
而對(duì)于ZEND_ITER_OBJECT的類對(duì)象,則會(huì)通過(guò)調(diào)用對(duì)象實(shí)現(xiàn)的Iterator接口相關(guān)函數(shù)來(lái)進(jìn)行foreach。
?php
/**
* Iterator模式的簡(jiǎn)單實(shí)現(xiàn)類
*/
class sample implements Iterator {
private $_items ;
public function __construct($data) {
$this->_items = $data;
}
public function current() {
return current($this->_items);
}
public function next() {
next($this->_items);
}
public function key() {
return key($this->_items);
}
public function rewind() {
reset($this->_items);
}
public function valid() {
return ($this->current() !== FALSE);
}
}
/** DEMO */
$data = array(1, 2, 3, 4, 5);
$sa = new sample($data);
foreach ($sa AS $key => $row) {
echo $key, ' ', $row, 'br />';
}
?>
舉幾個(gè)迭代器的使用范圍:
使用返回迭代器的包或庫(kù)時(shí)(如PHP5中的SPL迭代器)
無(wú)法在一次的調(diào)用獲取容器的所有元素時(shí)
要處理數(shù)量巨大的無(wú)素時(shí)(數(shù)據(jù)庫(kù)中的表以GB計(jì)的數(shù)據(jù))
……
不同的迭代器有不同的接口,例如PHP SPL迭代器中包括Next()(移動(dòng)到下一個(gè)元素),corrent()(返回當(dāng)前元素),valid()(檢查迭代結(jié)尾),rewind()(從頭重新開(kāi)始),key()(返回當(dāng)前元素的索引)。當(dāng)然你可以自己寫(xiě)適合自己用的迭代器,也可以用系統(tǒng)中的迭代器。
一般是使用foreach來(lái)使用迭代器,下面整理了一下代碼:
?php
class sample implements Iterator
{
private $_items = array(1,2,3,4,5,6,7);
public function __construct() {
;//void
}
public function rewind() { reset($this->_items); }
public function current() { return current($this->_items); }
public function key() { return key($this->_items); }
public function next() { return next($this->_items); }
public function valid() { return ( $this->current() !== false ); }
}
$sa = new sample();
foreach($sa as $key => $val){
print $key . "=>" .$val;
}
?>
while循環(huán)也可以:
?php
while ($itertor->valid()){ //判斷是不是最后元素
$element=$itertor->current(); //獲取當(dāng)前元素
$itertor->next(); //移動(dòng)到下一個(gè)元素
}
?>
為什么要學(xué)習(xí)PHP的迭代器呢?有個(gè)很重要的原因:利用PHP的迭代器可以利用面向?qū)ο髮?shí)現(xiàn)常見(jiàn)的數(shù)據(jù)結(jié)構(gòu),例如列表,堆棧,隊(duì)列與圖。后面會(huì)做一個(gè)專題,用PHP實(shí)現(xiàn)大部分的數(shù)據(jù)結(jié)構(gòu),而且以面向?qū)ο蟮男问?。所以這里先預(yù)熱了一下PHP的迭代器。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
您可能感興趣的文章:- PHP設(shè)計(jì)模式(九)外觀模式Facade實(shí)例詳解【結(jié)構(gòu)型】
- PHP設(shè)計(jì)模式之外觀模式(Facade)入門與應(yīng)用詳解
- thinkphp5.1框架中容器(Container)和門面(Facade)的實(shí)現(xiàn)方法分析
- 詳解PHP中的外觀模式facade pattern
- 學(xué)習(xí)php設(shè)計(jì)模式 php實(shí)現(xiàn)門面模式(Facade)
- php設(shè)計(jì)模式 Facade(外觀模式)
- PHP設(shè)計(jì)模式之工廠模式(Factory Pattern)的講解
- 淺談PHP設(shè)計(jì)模式之門面模式Facade